SpringCloud第二讲 Ribbon负载均衡源码分析

前言介绍:

      这一讲我们将依据Eureka的负载均衡规则,Eureka的具体服务搭建以及服务注册和服务发现可以参考基于Eureka实现服务注册和服务发现_热爱Java的编程小白的博客-CSDN博客

      Eureka的服务搭建之后便可以在这上面进行服务注册,如果存在两个相同的服务名注册,此时服务请求这个相同名称的服务的时候,将会配合Ribbon进行负载均衡处理,换言之,会在注册的同名服务列表中拉取其中一个服务处理本次请求。因此本讲将详细介绍Ribbon的负载均衡策略源码。

源码介绍:(基于idea工具进行讲解)

      双击键盘Shift打开全局搜索,输入LoadBalancerInterceptor进入到这个类里面,我们可以看到这个类实现了ClientHttpRequestInterceptor这个接口,这个接口是请求拦截器。这个接口会将请求进行拦截并且做负载均衡处理

       进入接口会发现这个接口只有一个实现拦截方法,那么负载均衡将会基于这个拦截方法进行负载均衡处理。

      进入方法查看发现会获取地址信息,服务名,获取到的服务名称,将会依据获取到的服务名称拉取从Eureka上拉取的同名服务实例。

       继续往下执行会发现allServerList已经从Eureka上拉取到这两个服务名称相同的服务实例

       继续跟进rule.choose(key),将会选择轮询还是随机,进入Rule接口

 将会看到里面有轮询和随机方法,但是这里用到的实现类是ZoneAvidanceRlue(),这个实现类是以区域可用的服务器为基础进行服务器的选择。使用Zone对服务器进行分类,这个Zone可以理解为一个机房,一个机架等。而后再对Zone内的多个服务做轮询。

 最后成功拿到实例。

Ribbon负载均衡源码分析就到这了,希望对大家有帮助!

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值