OpenFeign的实现原理(附Feign和OpenFeign的区别)
目录
问题现象:
问题分析:
拓展:
1、Feign:
2、OpenFeign:
问题现象:
最近在复习SpringCloud的时候看到一个面试题:
OpenFeign的实现原理?
问题分析:
OpenFeign是Spring Cloud自己研发的,是对第一代SpringCloud(SpringCloud Netflix)的Fegin组件的增强,支持Hystrix 、Ribbon和SpringMVC 注解。使得Feign 的使用更加方便。
这里我就结合个人理解,大概的总结一下OpenFeign的实现原理:
- 在 Spring 项目启动阶段,启动类上的@EnableFeignClients注解,会引入一个FeignClientsRegistrar(Feign客户端注册类),它会从指定的目录下扫描并加载所有被 @FeignClient 注解修饰的接口类(interface),然后将这些接口类型注册成 Bean对象,统一交给 Spring 来管理。
- @FeignClient 修饰的接口类的方法,经过 MVC Contract 协议的解析后,放入 MethodMetadata(方法元数据)数组中。
- 然后创建一个动态代理对象Proxy ,指向了一个存放着key为@FeignClient 修饰的接口类的方法名,和 value为方法名对应的MethodHandler (MethodHandler 记录着MethodMetadata方法元数据的引用)的 HashMap。然后把动态代理对象Proxy添加到 Spring 容器中,并注入到对应的服务里。
- 当服务调用FeignClient接口类的方法时,从动态代理对象 Proxy 中找到一个 MethodHandler 实例,生成一个包含该方法URL的 Http请求(不包含服务的 IP)。
- 经过Ribbon负载均衡算法找到一个服务的 IP 地址,拼接出完整的 URL,并发起请求。
- 被调用服务收到Http请求,就可以响应请求,返回数据给调用者了。
借用知乎大佬文章中的一张网图:
如果想要了解详细原理的伙伴,可以参考我在知乎上看到的一篇大佬写的文章,我觉得写得挺详细的:
10000字 | 深入理解 OpenFeign 的架构原理 - 知乎
拓展:
Feign和OpenFeign的区别?
1、Feign:
Feign是Netflix公司(第一代SpringCloud)研发的一个轻量级RESTful的伪HTTP服务客户端。
Feign内置了Ribbon逻辑,通过负载均衡算法可以从注册中心中寻找服务。
2、OpenFeign:
OpenFeign是SpringCloud自己研发的,在Feign的基础上做了增强。
OpenFeign除了原有Ribbon逻辑外,还支持了Hystrix和Spring MVC注解。