• 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注解

  • 相关阅读:
    【数据结构学习笔记】18:线段树(单点修改)
    结构体的理解
    解决报错之org.aspectj.lang不存在
    PostgreSQL 给表添加自增字段脚本
    Vue路由&nodeJS环境搭建
    oracle实现搜索不区分大小写
    【Highway-env】IntersectionEnv代码阅读
    文献学习-4-面向机器人手术的基于数据驱动控制的连续体腹腔镜器械跟踪控制方法
    洛谷_P1320、P1830 压缩技术和轰炸Ⅲ
    曲线救国|基于函数计算FC3.0部署AI数字绘画stable-diffusion
  • 原文地址:https://blog.csdn.net/weixin_42585386/article/details/127760999