基于SpringCloud的分布式微服务系统中各个服务之间的调用时通过http协议来完成的,提到http协议,最先想到的就是ip+端口+资源路径的调用方式,但是这种调用方式并不符合微服务架构下的服务治理的要求,微服务架构中的服务治理是以注册中心为中心的,这种调用方式明显脱离了注册中心,此时Ribbon和Feigin就诞生了。
首先说Ribbon,Ribbon的主要作用有两个,一个是将http调用与eureka相关联,通过服务名称获取服务对应的调用地址,二是提供不同的负载均衡策略,这一点与dubbo中的ClusterInvoker功能类似,但此时仍然是基于RestTemplate+url的方式来调用服务,在使用上不仅麻烦而且不利于管理,这时就诞生了Feign,Feign说白了就是对RestTemplate的一个封装,将对http协议的url的调用转换成对java 接口的调用,这更加符合面向对象的设计原则,此外,feign还提供了一些额外的功能,比如超时时间的设置、数据压缩供等,可以说,Ribbon和Feign是相互完善和补充的关系。
对于Ribbon和Feign的使用这里就不做介绍了,网上有很多的资料,同时也可以参考官方网站,下面主要来看一下Ribbon和Feigin的源码,看看具体的实现原理,这样可以做到知己知彼,使用的时候更加的得心应手。
因为Ribbon是基础,所以首先来看看Ribbon的源码。
按照SpringBoot的风格首先会有一个RibbonAutoConfiguration,到对应的依赖包中能够找到这个类
找到了入口,下面到这个类中看看ribbon的负载均衡和面向服务名称的调用时如何做到的。