Hystrix核心源码剖析

分析入口:@EnableCircuitBreaker注解激活了熔断功能,那么该注解就是Hystrix源码追踪的入口

@EnableCircuitBreaker注解激活熔断器

查看EnableCircuitBreakerImportSelector类 

继续关注父类 SpringFactoryImportSelector 

spring.factories文件内容如下 

会注入org.springframework.cloud.netflix.hystrix.HystrixCircuitBreakerConfiguration 

关注切面:com.netflix.hystrix.contrib.javanica.aop.aspectj.HystrixCommandAspect 

重点分析环绕通知方法 

        GenericCommand中根据元数据信息重写了两个很核心的方法,一个是run方法封装了对原始目标方法的调用,另外一个是getFallBack方法它封装了对回退方法的调用另外,在GenericCommand的上层类构造函数中会完成资源的初始化,比如线程池
GenericCommand —>AbstractHystrixCommand—>HystrixCommand—>AbstractCommand 

接下来回到环绕通知方法那张截图 

进入execute执行这里 

        另外,我们观察,GenericCommand方法中根据元数据信息等重写了run方法(对目标方法的调用),getFallback方法(对回退方法的调用),在RxJava处理过程中会完成对这两个方法的调用。