对任意方法调用(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" />
**