Ribbon负载均衡

1.负载均衡原理

order-service在调用user-service时,发送请求的地址是 http://userservuce/user/1,显然这个地址并不是一个真实可用的地址,在发送该请求时,Ribbon会将此请求拦截下来,拿到服务名称之后,向eureka-server拉去userservice服务,eureka-server会返回两个服务列表(因为我的项目里面user-service有两个端口),然后Ribbon再去做负载均衡,从两个里面挑一个。

order-service发起请求后会被LoadBalanceInterceptor负载均衡拦截器拦截,获取请求中的服务名称,把它交给RibbonLoadBanlanceClient,然后RibbonLoadBanlanceClient会把服务交给DynamicServerListLoadBalancer,它会向eureka-server拉取服务列表,然后根据IRule会基于规则(例如:轮询),挑选服务,然后由RibbonLoadBanlanceClient取替换ip和端口,发起请求。

2.负载均衡策略

由上可知Ribbon的负载均衡规则是一个叫Rule的接口来定义的,没一个子接口都是一种规则,下面是IRule的接口实现。

这是相关规则的描述

如何改变负载均衡的规则,以下有两种方式

1.代码实现:在order-service的OrderApplication的类中,定义一个新的IRule:

这种方式无论是调用那种方式,都采用的是RandomRule

2.配置文件方式:在order-service中的application.yml文件里面,添加新的配置

这种配置方案是针对userservice服务的,只有调用该服务才是用的随机规则

3.饥饿加载

Ribbon默认采用的是懒加载,即第一次访问时才会取创建LoadBalanceClient,请求时间会很长,而饥饿加载则会在项目启动时创建,降低第一次访问的耗时,通过下面配置开启饥饿加载:

相关推荐
⑩-39 分钟前
SpringCloud-Feign&RestTemplate
后端·spring·spring cloud
别来无恙blwy41 分钟前
SQL Server高可用自动故障转移失败(短时间内多次转移失败,只需一步可处理)
数据库·windows·sqlserver·负载均衡·可用性测试
楠枬5 小时前
OpenFeign
java·spring cloud·微服务
黄俊懿7 小时前
【深入理解SpringCloud微服务】Gateway简介与模拟Gateway手写一个微服务网关
spring boot·后端·spring·spring cloud·微服务·gateway·架构师
爬山算法7 小时前
Netty(23)Netty的负载均衡和高可用性如何实现?
运维·负载均衡
我是小妖怪,潇洒又自在7 小时前
springcloud alibaba(十)分布式事务
分布式·spring cloud·wpf
RemainderTime9 小时前
(十)Spring Cloud Alibaba 2023.x:生产级 CI/CD 全链路实战(从 Dockerfile 到 Jenkins)
运维·spring cloud·ci/cd·docker·jenkins
JHC0000001 天前
dy直播间评论保存插件
java·后端·python·spring cloud·信息可视化
华大哥1 天前
spring cloud微服务实战:consul+Feign/Ribbon服务注册和远程调用
spring cloud·微服务·ribbon·consul·java-consul
黄俊懿2 天前
【深入理解SpringCloud微服务】Seata(AT模式)源码解析——全局事务的提交
java·后端·spring·spring cloud·微服务·架构·架构师