浅谈Ribbon原理(就这么回事)

        首先Ribbon是Spring Cloud的核心组件之一,使用很简单,核心代码如下:

@Bean
@LoadBalanced
RestTemplate restTemplate() {
    return new RestTemplate();
}

需要明确的是@LoadBalanced注解是Spring的而非Ribbon的,且我们加上了@Bean注解,所以在spring启动时会将它注入到spring容器中,Ribbon通过一个@LoadBalanced注解就实现了RestTemplate请求的负载均衡,它具体的执行过程如下:

  1. 第一步客户端通过RestTemplate调用服务端的服务
  2. 请求首先被:LoadBalancerInterceptor类(负载均衡拦截器)拦截
  3. LoadBalancerInterceptor类有个LoadBalancerInterceptor方法,该方法入参为LoadBalancerClient对象
  4. 通过LoadBalancerClient可以获取到ILoadBalancer接口,通过该接口的方法可以查询到所有的服务列表
  5. ILoadBalancer(BaseLoadBalancer为其实现类之一)它的实现类里有个IRule接口,该接口就是用来设置负载均衡策略的,默认使用的是轮询,可通过配置文件设置。

  6. Ribbon提供了七种负载均衡策略
    浅谈Ribbon和nginx负载均衡的区别
    名称解释
    RoundRobinRule轮训策略
    RandomRule随机策略
    BestAvailableRule过滤出故障服务器后,选择一个并发量最小的
    WeightedResponseTimeRule针对响应时间加权轮询
    AvailabilityFilteringRule可用过滤策略,先过滤出故障的或并发请求大于阈值的一部分服务实例,然后再以线性轮询的方式从过滤后的实例清单中选出一个;
    ZoneAvoidanceRule从最佳区域实例集合中选择一个最优性能的服务实例
    RetryRule选择一个Server,如果失败,重新选择一个Server重试
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值