OpenFeign的实现原理(附Feign和OpenFeign的区别)

目录

问题现象:

问题分析:

拓展:

1、Feign:

2、OpenFeign:


问题现象:

        最近在复习SpringCloud的时候看到一个面试题:

        OpenFeign的实现原理?


问题分析:

        OpenFeignSpring Cloud自己研发的,是对第一代SpringCloud(SpringCloud Netflix)Fegin组件的增强,支持Hystrix RibbonSpringMVC 注解。使得Feign 的使用更加方便。

        这里我就结合个人理解,大概的总结一下OpenFeign的实现原理:

  1. 在 Spring 项目启动阶段,启动类上的@EnableFeignClients注解,会引入一个FeignClientsRegistrar(Feign客户端注册类),它会从指定的目录下扫描并加载所有被 @FeignClient 注解修饰的接口类(interface),然后将这些接口类型注册成 Bean对象,统一交给 Spring 来管理。
  2. @FeignClient 修饰的接口类的方法,经过 MVC Contract 协议的解析后,放入 MethodMetadata(方法元数据)数组中。
  3. 然后创建一个动态代理对象Proxy ,指向了一个存放着key为@FeignClient 修饰的接口类的方法名,和 value为方法名对应的MethodHandler (MethodHandler 记录着MethodMetadata方法元数据的引用HashMap。然后把动态代理对象Proxy添加到 Spring 容器中,并注入到对应的服务里。
  4. 当服务调用FeignClient接口类的方法时,从动态代理对象 Proxy 中找到一个 MethodHandler 实例,生成一个包含该方法URL的 Http请求(不包含服务的 IP)。
  5. 经过Ribbon负载均衡算法找到一个服务的 IP 地址,拼接出完整的 URL,并发起请求。
  6. 被调用服务收到Http请求,就可以响应请求,返回数据给调用者了。

        借用知乎大佬文章中的一张网图:

        如果想要了解详细原理的伙伴,可以参考我在知乎上看到的一篇大佬写的文章,我觉得写得挺详细的:

        10000字 | 深入理解 OpenFeign 的架构原理 - 知乎


拓展:

        Feign和OpenFeign的区别?

1、Feign:

        FeignNetflix公司(第一代SpringCloud研发的一个轻量级RESTful的伪HTTP服务客户端。

        Feign内置了Ribbon逻辑,通过负载均衡算法可以从注册中心中寻找服务。

2、OpenFeign:

        OpenFeignSpringCloud自己研发的,在Feign的基础上做了增强。

        OpenFeign除了原有Ribbon逻辑外,还支持了HystrixSpring MVC注解

  • 1
    点赞
  • 36
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值