Ribbon-IRule 修改负载均衡的规则

1、负载均衡规则描述

 (1)整体关系

Ribbon-IRule 修改负载均衡的规则_第1张图片

 (2)规则描述

内置负载均衡规则类 规则描述
RoundRobinRule 简单轮询服务列表来选择服务器。它是Ribbon默认的负载均衡规则。
AvailabilityFilteringRule 对以下两种服务器进行忽略:
(1)在默认情况下,这台服务器如果3次连接失败,这台服务器就会被设置为“短路”状态。短路状态将持续30秒,如果再次连接失败,短路的持续时间就会几何级地增加。(2)并发数过高的服务器。如果一个服务器的并发连接数过高,配置了AvailabilityFilteringRule规则的客户端也会将其忽略。并发连接数的上限,可以由客户端的ActiveConnectionsLimit属性进行配置。
WeightedResponseTimeRule 为每一个服务器赋予一个权重值。服务器响应时间越长,这个服务器的权重就越小。这个规则会随机选择服务器,这个权重值会影响服务器的选择。
ZoneAvoidanceRule 以区域可用的服务器为基础进行服务器的选择。使用Zone对服务器进行分类,这个Zone可以理解为一个机房、一个机架等。而后再对Zone内的多个服务做轮询。
BestAvailableRule 忽略哪些短路的服务器,并选择并发数较低的服务器。
RandomRule 随机选择一个可用的服务器。
RetryRule 重试机制的选择逻辑。

2、负载均衡规则方式

 (方式1)在服务的Application类中,定义IRule,这种方式全局生效。

@Bean
public IRule randomRule(){
        return new RandomRule;

}

 (方式2)在服务的application.yml,定义配置修改规则,这种方式可以针对某个服务进行配置。 

userservice:
        ribbon:
        NFLoadBalancerRuleClassName: com.netfix.loadbalancer.RandomRule

3、举例

(方式1)例

Ribbon-IRule 修改负载均衡的规则_第2张图片

(方式2)例

Ribbon-IRule 修改负载均衡的规则_第3张图片

你可能感兴趣的:(ribbon,负载均衡,java,eclipse,spring,cloud,spring)