使用场景:对任意方法调用(METHOD),提供无侵入,配置式的增强。不需要修改原来的方法,即可给你的程序加入这些特性:*1、异常重试*2、缓存机制*3、超时控制*4、并行支持*6、服务降级*7、异常模块(比如依赖的远程服务失效)的短路控制*8、流量限制(方法调用次数控制)PS:1、上述所有支持的特性都是“正交的”(正交性:互不影响,任意组合)2、在使用并行和超时控制的时候,由于线程会walkawayfromcurrentthread:所以对于任何线程变量(ThreadLocal)的访问,和参数中非线程安全的对象引用都需要多加小心。3、由于Enhancer的状态机囿于一个Jvm中,所以对于分布式环境,需要更多的考虑:比如流量限制模块就需要结合LoadBalance策略考虑4、bestpractice:可以与分布式配置中心,或Monitor结合,以提供分布式环境的集成5、可以实现许多有用的功能比如:场景1:有个web项目,现在有功能需要上线发布,由于后方依赖还没上线,不希望用户方法方法。用框架的短路功能将这个功能短路即可。场景2:比如web项目的一个restful接口,如果输入非常大则耗时很长,同时有大量输入还有可能打满线程池。那么传统的做法可以修改代码增加一个参数量或者范围限制,但是这样的弊端就是要改代码,如果要可配置动态调整,还是有不小的workload,范围太小还会阻碍大部分用户正常使用。所以,可以增加一个超时控制,来更直观地控制服务稳定性。场景3:比如公司某rpc接口,给各个使用方提供服务。但是对“试用用户”有调用次数限制,那么可以使用短路模块(实现ShortCircuitProxy)自定义流量控制功能(比如分用户count,一小时多少次)。安利一下:只需要在xml中添加两行,就能拥有这些功能!(依赖Spring)<aop:aspectj-autoproxy/><context:component-scanbase-package="com.baidu.aenhancer"/>声明:本文仅代表作者观点,不代表本站立场。如果侵犯到您的合法权益,请联系我们删除侵权资源!如果遇到资源链接失效,请您通过评论或工单的方式通知管理员。未经允许,不得转载,本站所有资源文章禁止商业使用运营!
下载安装【程序员客栈】APP
实时对接需求、及时收发消息、丰富的开放项目需求、随时随地查看项目状态
评论