OpenFeign原理

OpenFeign原理

feign调用就是用来简化远程调用代码的,使得远程调用就像本地调用一样简单.

openfeign核心流程

img

  1. spring项目启动中,服务A的openfeign框架会发起一个主动扫包的过程.

  2. 从指定目录下加载所有被@FeignClient修饰的接口,将这些接口转换为Bean,交给spring来管理.

  3. 这些接口会经过MVC constract解析, 将方法上的注解解析出来放到MethodMetadata中.

  4. 每一个FeignClient接口会生成一个动态代理对象,指向包含方法的MethodHandler的HashMap.

  5. 服务A发起远程调用

  6. 从动态代理proxy中找到一个MethodHandler的实例, 生成request,包含请求的url.

  7. 经过负载均衡算法找到一个服务的IP地址,拼接请求的URL.

  8. 服务B处理服务A发起的远程调用,执行逻辑后,返回响应给A.

openfeign扫包原理

@EnableFeignClients注解会查找所有带有@FeignClient注解的类和接口. 然后只保留带有@FeignClient的接口.

注册FeignClient到Spring原理

img

*解析@FeignClient定义的属性’

*将注解@FeignClient的属性和接口的信息构造成一个beanDefination

*将beanDefination转换成一个holder,这个holder就包括beandefination, alias, beanName信息.

*最后将这个holder注册到 Sprng容器中.

openfeign 动态代理

img

  • 解析FeignClient接口上各个方法的注解,比如url, 接口类型,参数等.
  • 将解析好的数据封装成元数据, 为每一个方法生成一个MethodHandler类的代理,相当于把服务请求地址,接口类型都封装好了,这些MethodHandler会放到一个HashMap中.
  • 生成一个InvacationHandler来管理这些hashmap,其中Dispath指向这个HashMap.
  • 使用JDK动态代理实现了FeignClient接口的动态代理对象proxy,将这个proxy添加到Spring容器中
  • 调用方法时, 就会调用动态代理Proxy对象的methodHandler来发送请求.

总结

  • OpenFeign会扫描带有@FeignClient接口的注解,为其生成一个动态代理对象.
  • 动态代理里包含接口方法的MethodHandler, MethodHandler里又包括经过MVC Constract解析注解后的元数据
  • 发起请求时MeathodHandler会生成一个Request
  • 负载均衡Ribbon会从服务列表中选取一个Server, 拿到对应的IP地址后拼接URL, 就可以发起远程调用了.

on会从服务列表中选取一个Server, 拿到对应的IP地址后拼接URL, 就可以发起远程调用了.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
【2021年,将Spring全家桶系列课程进行Review,修复顺序等错误。进入2022年,将Spring的课程进行整理,整理为案例精讲的系列课程,并新增高级的Spring Security等内容,通过手把手一步步教你从零开始学会应用Spring,课件将逐步进行上传,敬请期待】 本课程是Spring案例精讲课程的第四部分Spring Cloud,Spring案例精讲课程以真实场景、项目实战为导向,循序渐进,深入浅出的讲解Java网络编程,助力您在技术工作中更进一步。 本课程聚焦Spring Cloud的核心知识点:注册中心、服务提供者与消费者、服务的调用OpenFeign、Hystrix监控、服务网关gateway、消息驱动的微服务Spring Cloud Stream、分布式集群、分布式配置中心的案例介绍, 快速掌握Spring Cloud的核心知识,快速上手,为学习及工作做好充足的准备。 由于本课程聚焦于案例,即直接上手操作,对于Spring的原理等不会做过多介绍,希望了解原理等内容的需要通过其他视频或者书籍去了解,建议按照该案例课程一步步做下来,之后再去进一步回顾原理,这样能够促进大家对原理有更好的理解。【通过Spring全家桶,我们保证你能收获到以下几点】 1、掌握Spring全家桶主要部分的开发、实现2、可以使用Spring MVC、Spring Boot、Spring Cloud及Spring Data进行大部分的Spring开发3、初步了解使用微服务、了解使用Spring进行微服务的设计实现4、奠定扎实的Spring技术,具备了一定的独立开发的能力  【实力讲师】 毕业于清华大学软件学院软件工程专业,曾在Accenture、IBM等知名外企任管理及架构职位,近15年的JavaEE经验,近8年的Spring经验,一直致力于架构、设计、开发及管理工作,在电商、零售、制造业等有丰富的项目实施经验  【本课程适用人群】如果你是一定不要错过!  适合于有JavaEE基础的,如:JSP、JSTL、Java基础等的学习者没有基础的学习者跟着课程可以学习,但是需要补充相关基础知识后,才能很好的参与到相关的工作中。 【Spring全家桶课程共包含如下几门】 

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值