SpringCloud——负载均衡——Ribbon

负载均衡分为集中式 LB(Nginx实现)和进程内LB(Ribbon)。

Ribbon简单来说就是负载均衡 +RestTemplate调用

1.Ribbon在工作中分成两步

1.先选择EurekaServer,它优先选择在同一个区域内负载较少的EurekaServer。

2.在根据用户指定的策略,从服务注册的列表上选择一个地址。

注意:spring-cloud-starter-netflix-eureka-client这个jar内部引入了ribbon

2.轮询算法的继承结构

3.Ribbon默认轮询算法的原理

里面会有一个调用服务次数的计数器,采用 计数器 %此服务实例的个数 = 最终调用的服务的下标索引。服务每次重启的话,计数器又从1重新开始。

4.手写轮询算法

CAS+自旋的思想,要实现在实例的列表中选择一个并返回。

相关推荐
梁bk3 小时前
[Nginx]反向代理和负载均衡
运维·nginx·负载均衡
guojl14 小时前
RestTemplate使用手册
spring cloud·微服务
guojl14 小时前
RestTemplate原理分析
spring cloud·微服务
Ken_111514 小时前
SpringCloud系列(51)--SpringCloud Stream之使用分组解决消息重复消费问题
spring cloud
lwb_011816 小时前
SpringCloud——Gateway新一代网关
spring·spring cloud·gateway
述雾学java19 小时前
Spring Cloud Feign 整合 Sentinel 实现服务降级与熔断保护
java·spring cloud·sentinel
何苏三月1 天前
SpringCloud系列 - Sentinel 服务保护(四)
spring·spring cloud·sentinel
你不知道我是谁?1 天前
负载均衡--常见负载均衡算法
运维·负载均衡
星融元asterfusion1 天前
基于路径质量的AI负载均衡异常路径检测与恢复策略
人工智能·负载均衡·异常路径
小马爱打代码1 天前
微服务外联Feign调用:第三方API调用的负载均衡与容灾实战
微服务·架构·负载均衡