AEnhancer轻量级切面增强框架
使用场景:
对任意方法调用(METHOD),提供无侵入,配置式的增强。不需要修改原来的方法,即可给你的程序加入这些特性:
* 1、异常重试
* 2、缓存机制
* 3、超时控制
* 4、并行支持
* 6、服务降级
* 7、异常模块(比如依赖的远程服务失效)的短路控制
* 8、流量限制(方法调用次数控制)
PS:
1、上述所有支持的特性都是“正交的”(正交性:互不影响,任意组合)
2、在使用并行和超时控制的时候,由于线程会walk away from current thread:
所以对于任何线程变量(ThreadLocal)的访问,和参数中非线程安全的对象引用都需要多加小心。
3、由于Enhancer的状态机囿于一个Jvm中,所以对于分布式环境,需要更多的考虑:
比如流量限制模块就需要结合LoadBalance策略考虑
4、best practice:可以与分布式配置中心,或Monitor结合,以提供分布式环境的集成
5、可以实现许多有用的功能比如:
场景1:有个web项目,现在有功能需要上线发布,由于后方依赖还没上线,不希望用户方法方法。
用框架的短路功能将这个功能短路即可。
场景2:比如web项目的一个restful接口,如果输入非常大则耗时很长,同时有大量输入还有可能打满线程池。
那么传统的做法可以修改代码增加一个参数量或者范围限制,但是这样的弊端就是要改代码,如果要可配置动态调整,
还是有不小的workload,范围太小还会阻碍大部分用户正常使用。所以,可以增加一个超时控制,来更直观地控制
服务稳定性。
场景3:比如公司某rpc接口,给各个使用方提供服务。但是对“试用用户”有调用次数限制,那么可以使用短路模块
(实现ShortCircuitProxy)自定义流量控制功能(比如分用户count,一小时多少次)。
安利一下:
只需要在xml中添加两行,就能拥有这些功能!(依赖Spring)
<aop:aspectj-autoproxy />
<context:component-scan base-package="com.baidu.aenhancer" />
* 1、异常重试
* 2、缓存机制
* 3、超时控制
* 4、并行支持
* 6、服务降级
* 7、异常模块(比如依赖的远程服务失效)的短路控制
* 8、流量限制(方法调用次数控制)
评论