内容简介:Jboot 是一个基于 JFinal、JFinal-Undertow、Dubbo、Seata、Sentinel、ShardingSphere、Nacos 等开发的微服务框架,帮助开发者降低微服务开发门槛。同时完美支持在 idea、eclipse 下多 maven 模块,对 java 代码、...
Jboot 是一个基于 JFinal、JFinal-Undertow、Dubbo、Seata、Sentinel、ShardingSphere、Nacos 等开发的微服务框架,帮助开发者降低微服务开发门槛。同时完美支持在 idea、eclipse 下多 maven 模块,对 java 代码、html、css、js 等资源文件进行热加载。爽爽开发,快乐生活。
在 Jboot v3.5.0 中,我们新增了一个全新的组件:InterceptorBuilder。
InterceptorBuilder 能够根据当前 Controller、Service 的方法,来对当前方法应该使用哪些拦截器进行构建,在之前 JFinal 的体系里,给某个方法添加拦截器只能通过 @Before({MyInterceptor.class}) 或者 configInterceptor() 配置方法里添加全局拦截器。
这样带来一个不够优雅的地方是,如果我们想给某个方法 ”增强“,只能以添加全局拦截器的方式来做,在 Jboot 中,如果我们想让某个方法拥有缓存功能,可以使用注解 @Cacheable ,如下代码:
@Cacheable(name = "cacheName", key = "#(id)", liveSeconds = 5)
public String findCommentById(String id) {
// your code
}
这个 @Cacheable 的注解的含义是:方法 findCommentById 的数据结果,会根据其 id 缓存 5 秒的时候,在 5 秒内通过同一个 id 去获取,都是直接从缓存中获取,不再执行 findCommentById 这个方法。5 秒之后,改缓存自动失效,如果再调用此方法又会重新执行。
在 Jboot 中,除了缓存,还有 Sentinel 限流和降级机制、Seata 分布式事务、Metrics 监控等等组件都是使用了类似的处理方案。
在过去 JFinal 的机制中,这种方案只能通过唯一一种方法就是添加全局拦截器,每个方法都是通过拦截器执行,然后拦截器再来判断该方法是否有注解比如 @Cacheable 等。这样就带来了性能效率的下级,因为在我们整个系统中,有非常多的方法是没有 @Cachea 主要的注解的,他本身已经明确不需要缓存等这些特征的。
有了 InterceptorBuilder 之后,我们可以通过 InterceptBuilder 给某个方法来构建其特定的拦截器,而不是全局拦截器,这样,极大的提高了性能,同时减少了不必要的调用堆栈。
因为有了 InterceptorBuilder 之后,Jboot 之前内置的 FixedInterceptor 组件也被移除了,如果需要类型 FixedInterceptor 的拦截器,我们可以通过自定义 InterceptorBuilder 来进行构建即可。
如何使用 InterceptorBuilder 呢?如下代码:
public void onInit() {
InterceptorBuilderManager.me().addInterceptorBuilder(new MyInterceptorBuilder());
}
比如 @Cacheable 的拦截器构建 CacheInterceptorBuilder 代码如下:
public class CacheInterceptorBuilder implements InterceptorBuilder {
@Override
public void build(Class<?> serviceClass, Method method, Interceptors interceptors) {
Cacheable cacheable = method.getAnnotation(Cacheable.class);
if (cacheable != null) {
interceptors.add(new CacheableInterceptor());
}
}
}
在方法 build 中的 Interceptors,我们不仅仅可以通过 Interceptors 来添加拦截器,我们还可以通过其来删除拦截器、或者移动拦截器位置等等操作。
除此之外,Jboot 3.5.0 带来了更加好用和稳定的分布式文件管理机制,和全新的文档,分别托管在 gitee page 和 github上。
访问地址:http://jboot.io (这个放在github上,会有点慢)
国内镜像:http://jbootprojects.gitee.io/docs
目前已经开源超过了 3 年的时间,迭代了 100+ 个版本,已经被超过 1000+ 公司在使用。欢迎你来使用、体验 和 吐槽这个类似 SpringCloud 却不一样的框架。
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- 全新版本网易云音乐来啦
- Arthas 3.4.6 版本发布,全新版本的热更新功能
- Arthas 3.4.6 版本发布,全新版本的热更新功能
- jemalloc 5.0.0 全新版本发布,内存分配管理
- 安全的全新V语言发布首个可用版本
- 禅道发布 15 版本第一个版本,内置项目集和管理模型概念,全新导航体系
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
高可用架构(第1卷)
高可用架构社区 / 电子工业出版社 / 2017-11-1 / 108.00元
《高可用架构(第1卷)》由数十位一线架构师的实践与经验凝结而成,选材兼顾技术性、前瞻性与专业深度。各技术焦点,均由极具代表性的领域专家或实践先行者撰文深度剖析,共同组成“高可用”的全局视野与领先高度,内容包括精华案例、分布式原理、电商架构等热门专题,及云计算、容器、运维、大数据、安全等重点方向。不仅架构师可以从中受益,其他IT、互联网技术从业者同样可以得到提升。一起来看看 《高可用架构(第1卷)》 这本书的介绍吧!