第六章 SpringCloud-Ribbon负载均衡

Ribbon 负载均衡
负载均衡算法: 随机,轮询(Ribbon默认),hash,最小访问

实现:
1. 在消费者pom中添加依赖

<dependency>
  <groupId>org.springframework.cloud</groupId>
  <artifactId>spring-cloud-starter-netflix-ribbon</artifactId>
</dependency>

2. 在restTemplate实例化方法上加上注解 @LoadBalanced
3. 将URL改成 http://服务ID

修改负载均衡算法配置

*# 改为随机*
user-server.NFLoadBalancerRuleClassName:  com.netflix.loadbalancer.RandomRule

在这里插入图片描述
拓展:
负载均衡里面获取Url的代码(类RibbonLoadBalancerClient):

 Server server = this.getServer(loadBalancer, hint);

负载均衡默认轮询代码(BaseLoadBalancer类)

private final static IRule DEFAULT_RULE = new RoundRobinRule();

轮询算法:

 private int incrementAndGetModulo(int modulo) {
        for (;;) {
            int current = nextIndex.get();
            int next = (current + 1) % modulo;
            if (nextIndex.compareAndSet(current, next) && current < modulo)
                return current;
        }
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值