SpringCloud之Bibbon源码分析

Ribbon 源码解析

Ribbon 运行的时候是创建一个RestTemplate 然后在加一个@LoadBalancer的注解 接口即可完成ribbon的整合

那@LoadBalancer 做了那些工作呢 ?看下源码

会发现在这个包下有一个LoadBalancerAutoConfiguration的加载类 看下这个类做什么

加入loadBalancerClient.class 同时还有一些初始化的bean

看源码会发在有@loadBalancer注解修饰的restTmplate 会被加上一个拦截器

这样思路就清晰了 ribbon的负载是通过拦截器处理的

下面就看下拦截器是怎么处理的

看源码会发现这个主战场在ribbonLoadBalancerClinet.class

负载方法是choose()跟源码最终会找到 ILoadBalancer.class

 

 

DynamicServerListLoadBalancer.class 父类的加载策略

发现默认的负载策略是 RoundRobinRule()

这些是负载策略不同的实现类

WeightedResponseTimeRule:根据server响应平均时长来确定使用哪个server 响应时间越长,权重越小。

RandomRule: 随机选择一个可用的服务器。

RetryRule: 重试机制的选择逻辑

AvailabilityFilteringRule:并发下的

到此负载策略就分析完了,今天就到这里了  还有好多事情要做。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值