第一步
注解 EnableFeignClients 与 FeignClient
EnableFeignClients 是配置去扫描路径下的接口被FeignClient注释的,因为EnableFeignClients 上有@Import(FeignClientsRegistrar.class)这个注解FeignClientsRegistrar会根据你在EnableFeignClients 上配置的路径去扫描路径下的所有接口,并判断有没有FeignClient注解,然后把他包装成FeignClientFactoryBean类型的BeanDefinitio。这里面有包含的信息有,接口类、调用服务、熔断类等信息。
等二 步
spring实例化bean
因为向容器中注入的是FeignClientFactoryBean是一个FactoryBean在实例化的时候会去调用他的getObject得到实话对象。1.得到 FeignContext 的bean 配置 编码器、日志输出器、和一些配置。2.从FeignContext 得到 Client(LoadBalancerFeignClient这个就是用来连接调用远程服务的)Client 实例化的时候传入了两bean CachingSpringLoadBalancerFactory(缓存工厂) 和 SpringClientFactory(ribbon的负载均衡等熔断的工厂)
3.生成代理对象,生成代理对象的准备工作,解析这接口把所有的方法提出来。把它拼装成SynchronousMethodHandler对象,InvocationHandlerFactory.Default类把得到的方法解析结果和接口信息做成一个jdk代理对象,ReflectiveFeign.FeignInvocationHandler这个就是代理对象 InvocationHandler。这里面包含了接口信息和方法信息。
第三步
当调用这个接口得时候,他会去调用ReflectiveFeign.FeignInvocationHandler得invoke方法
一步步得调用到远程服务。
这里为什么Feign 能用Ribbon 能用并且用到了Eureka得服务,
关键点在于 下面红色方框里面 Feign 使用了Ribbon得ILoadBalancer得对象,ILoadBalancer(RibbonClientConfiguration)要注入ServerList得对象,而Eureka(EurekaRibbonClientConfiguration)重写了ServerList bean并且优先等级要比Ribbon自己写的高,所以Feign 用 Ribbon ,Ribbon 用Eureka 达成循环。
openfeign2.0.2与eureka2.0.2调用与联动
最新推荐文章于 2023-04-18 22:04:05 发布