加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

【SpringCloud】08.客户端负载均衡器:Ribbon

发布时间:2020-12-15 07:08:22 所属栏目:Java 来源:网络整理
导读:客户端负载均衡器:Ribbon Ribbon实现软负载均衡核心: 服务发现 :依据服务的名字,把该服务下所有的实例都找出来 服务选择规则 :依据规则策略,如果从多个实例中,选出有效的服务 服务监听 :检测失效的服务,做到高效剔除 Ribbon主要组件: ServerList

客户端负载均衡器:Ribbon

Ribbon实现软负载均衡核心:

  1. 服务发现 :依据服务的名字,把该服务下所有的实例都找出来
  2. 服务选择规则:依据规则策略,如果从多个实例中,选出有效的服务
  3. 服务监听:检测失效的服务,做到高效剔除

Ribbon主要组件:

  1. ServerList (获取所有的服务列表)
  2. IRule(根据规则选择出有效的)
  3. ServerListFilter(过滤掉失效的)

流程:

1.首先通过ServerList获取所有的服务列表
2.然后通过ServerListFilter过滤掉一部分地址
3.最后通过IRule选择一个实例,作为最终目标结果

默认负载均衡策略

  • 轮询

如何修改负载均衡策略

  • 去SpringCloud官网搜索Ribbon策略的配置(搜索:Customizing the Ribbon Client),可以找到从配置文件配置的方法

    需要在客户端配置如下:

PRODUCT:
  ribbon:
    NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RandomRule

PRODUCT : 应用名

RandomRule :负载均衡策略为随机 (Ribbon的默认策略默认是RoundRobinRule

所有的负载均衡策略在IRule接口中可以看到:

1554275423045.png

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读