SpringCloud总结:Feign&Ribbon

基于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的负载均衡和面向服务名称的调用时如何做到的。

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值