EnableFeignClients 注解
这个注解 @Import了一个类FeignClientsRegistrar,我们可以看到核心逻辑如下:
1 从EnableFeignClients 取出属性 clients 如果不为空则根据配置的clients来注册BeanDefinition
2 如果为空则扫描标注有FeignClient的类,进行注册。
注册逻辑如下FeignClientsRegistrar#registerFeignClient方法里面:
我们可以看到有一个FeignClientFactoryBean非常关键说明我们创建对象是FeignClientFactoryBean来创建的,这里写的是函数是编程引用了创建对象的方法,那么怎么和IOC容器创建对象的时候进行打通的呢?
关键就在Supplier<?> instanceSupplier = mbd.getInstanceSupplier();这里了,这得到对象直接返回,这个对象是由FeignClientFactoryBean来创建 。然后我们把目光移入FeignClientFactoryBean,核心逻辑在下面,这块就配置了FeignClient相关的东西,里面内容太多了,这里就不再展开了:
我们可以最终找到,创建代理对象的逻辑HystrixTargeter -> Feign -> ReflectiveFeign:
至于这个FeignContext实现如下:
这里是为每个FeignClinet创建了一个AnnotationConfigApplicationContext context = new AnnotationConfigApplicationContext();所以说FeignClinet与FeignClinet之间是隔离的。那为什么需要隔离呢?隔离以后我们可以通过configuration指定配置类,这个配置类包含了feign.codec.Decoder, feign.codec.Encoder, feign.Contract.组件,这样子的话可以相互不影响,比如我不通的Feign Clinet要使用不同的Encoder。
public class FeignConfiguration {
@Bean
public CustomRequestInterceptor customRequestInterceptor() {
return new CustomRequestInterceptor();
}
}
@FeignClient(value = "optimization-user", configuration = FeignConfiguration.class)
友情连接:https://blog.csdn.net/qq_43259860/article/details/135353984