【SpringCloud原理】OpenFeign原来是这么基于Ribbon来实现负载...
发布网友
发布时间:7小时前
我来回答
共1个回答
热心网友
时间:7小时前
欢迎来到本篇文章,之前我们已经深入探讨了OpenFeign的动态代理生成原理和Ribbon的运行机制。若要对OpenFeign的动态代理生成原理和Ribbon的运行原理有更深入的了解,可关注微信公众号“三友的java日记”,通过菜单栏查看整理的相关内容。接下来,我们将继续深入SpringCloud组件原理,探讨OpenFeign是如何利用Ribbon实现负载均衡的,以及两组件如何协同工作的。
一、Feign动态代理调用实现rpc流程解析
我们从Feign客户端接口的动态代理生成原理出发,了解到动态代理基于JDK实现,所有方法调用最终都会调用到InvocationHandler接口的实现,即ReflectiveFeign.FeignInvocationHandler。接下来,我们将深入探讨FeignInvocationHandler如何实现rpc调用。
FeignInvocationHandler通过invoke方法实现动态代理功能,其主要逻辑如下:
1. 对于调用的方法是否为equals、hashCode、toString等特殊方法进行判断,若为则无需走rpc调用。
2. 从dispatch获取调用方法对应的MethodHandler,然后调用MethodHandler的invoke方法。
3. MethodHandler在构建动态代理时生成,作用是最终实现rpc调用,每个方法有对应的MethodHandler。
4. SynchronousMethodHandler是实现rpc调用的关键类,通过构造RequestTemplate、Options和重试组件,发起http请求,并通过Client接口执行请求,返回响应数据。
二、LoadBalancerFeignClient与Ribbon整合
从整个动态代理调用流程来看,Client是关键组件,负责发送http请求。Feign是如何通过Ribbon实现负载均衡的呢?让我们进一步剖析。
通过整合配置类FeignRibbonClientAutoConfiguration,我们可以找到构造Feign.Builder实现的关键组件:LoadBalancerFeignClient。这个组件依赖于负载均衡,是Feign与Ribbon集成的入口。
LoadBalancerFeignClient实现的核心逻辑在于从请求的URL中提取服务名,通过缓存机制获取或创建FeignLoadBalancer,最终调用executeWithLoadBalancer方法发起请求,完成负载均衡与服务调用。
三、FeignLoadBalancer实现负载均衡与发送请求
FeignLoadBalancer是实现选择负载均衡和发送http请求的关键组件。其核心逻辑在于重构请求路径,将服务名替换为具体的服务器IP和端口,然后通过execute方法完成请求。
四、总结与图解
本篇文章完整阐述了OpenFeign、Ribbon与注册中心之间的协同工作原理。通过总结,我们了解到OpenFeign在进行RPC调用时,借助Ribbon选择负载均衡服务器,而Ribbon从注册中心获取服务器列表。通过这张图,我们可以清晰地看到三个组件之间的协同关系。
至此,我们完成了对这三个组件核心源码和流程的深入探讨。希望本篇文章能帮助读者理解微服务架构的基础原理,同时对OpenFeign、Ribbon、Nacos源码有更深入的认识。