1.netflix已经有了feign这个httpclient,源码为什么还要开发ribb
netflix已经有了feign这个httpclient,为什么还要开发ribb
Feign与Ribbon在设计上定位不同,Feign主打远程过程调用(RPC),源码虽然基于HTTP,源码但能屏蔽请求细节,源码用户只需声明接口,源码即可实现远程服务调用,源码多列排序模块源码无需关心HTTP请求细节或参数封装。源码而Ribbon则专注于负载均衡,源码RPC功能不是源码其强项,其主要优势在于从注册中心获取服务实例。源码二者互补,源码Feign无需Ribbon也能实现调用,源码只需指定服务IP和端口;Ribbon也无需Feign,源码但需实现HTTP请求参数封装。源码选择两者结合,源码约局麻将源码源于解耦和单一职责原则。
整合原理可参考相关文章。本文继续解析SpringCloud组件原理,重点剖析OpenFeign如何基于Ribbon实现负载均衡,以及二者如何协同工作。
一、Feign动态代理调用实现RPC流程分析
Feign客户端接口的小迪渗透源码动态代理生成基于JDK动态代理,通过FeignInvocationHandler实现方法调用。FeignInvocationHandler对invoke方法的实现避免了不需要RPC调用的方法(如equals、hashCode、toString)。通过dispatch获取要调用方法对应的MethodHandler,执行MethodHandler的invoke方法。MethodHandler在构建动态代理时生成,快活林源码负责实现RPC调用。SynchronousMethodHandler处理RPC调用,其invoke方法构建RequestTemplate,封装HTTP请求参数。执行findOptions(argv)获取配置参数,使用重试组件,最后调用Client接口实现请求发送。shiro 记住密码源码
二、LoadBalancerFeignClient
Feign动态代理调用的关键在于Client,用于发送HTTP请求。通过分析可知,Feign客户端构建动态代理时,填充组件包括LoadBalancerFeignClient,实现Ribbon整合。FeignRibbonClientAutoConfiguration配置类导入相关组件并声明LoadBalancerFeignClient,注入Client实现、CachingSpringLoadBalancerFactory和SpringClientFactory,构建Feign.Builder的实现。
LoadBalancerFeignClient实现整合过程,获取服务名,调用CachingSpringLoadBalancerFactory创建FeignLoadBalancer,实现负载均衡与请求发送。
三、FeignLoadBalancer
FeignLoadBalancer为核心组件,负责选择负载均衡并发送HTTP请求。执行executeWithLoadBalancer重构请求路径,调用execute方法,基于特定Client实现发送请求,最终返回RibbonResponse。
四、总结
本文全面解析了OpenFeign、Ribbon以及Nacos组件在微服务架构中的协同工作原理。OpenFeign实现RPC调用时,Ribbon从注册中心获取服务实例列表,实现负载均衡。Ribbon与Nacos(或其它注册中心)协同工作,确保服务发现和负载均衡的高效执行。通过本文,读者应能理解这三个组件在微服务架构中的作用,并对它们的源码有基本认识。