springcloud Ribbon负载均衡服务调用

文章目录

代码下载地址

地址:https://github.com/13thm/study_springcloud/tree/main/days6_Ribbon

简介

Spring Cloud Ribbon是基于Netflix Ribbon实现的一套客户端 负载均衡的工具。

简单的说,Ribbon是Netflix发布的开源项目,主要功能是提供客户端的软件负载均衡算法和服务调用。Ribbon客户端组件提供一系列完善的配置项如连接超时,重试等。简单的说,就是在配置文件中列出Load Balancer(简称LB)后面所有的机器,Ribbon会自动的帮助你基于某种规则(如简单轮询,随机连接等)去连接这些机器。我们很容易使用Ribbon实现自定义的负载均衡算法。

前面我们讲解过了80通过轮询负载访问8001/8002

负载均衡+RestTemplate调用

Ribbon核心组件IRule:

bash 复制代码
com.netflix.loadbalancer.RoundRobinRule  轮询
com.netflix.loadbalancer.RandomRule 随机
com.netflix.loadbalancer.RetryRule 先按照RoundRobinRule的策略获取服务,如果获取服务失败则在指定时间内会进行重试,获取可用的服务
WeightedResponseTimeRule  对RoundRobinRule的扩展,响应速度越快的实例选择权重越大,越容易被选择

BestAvailableRule  会先过滤掉由于多次访问故障而处于断路器跳闸状态的服务,然后选择一个并发量最小的服务
AvailabilityFilteringRule  先过滤掉故障实例,再选择并发较小的实例
ZoneAvoidanceRule 默认规则,复合判断server所在区域的性能和server的可用性选择服务器

如何替换:

  1. 修改cloud-consumer-order80

    官方文档明确给出了警告:

    这个自定义配置类不能放在@ComponentScan所扫描的当前包下以及子包下,

    否则我们自定义的这个配置类就会被所有的Ribbon客户端所共享,达不到特殊化定制的目的了。

  2. 新建package

  3. 上面包下新建MySelfRule规则类

  4. 主启动类添加@RibbonClient

测试

bash 复制代码
http://localhost/consumer/payment/get/1

变成了随机生成的了

Ribbon负载均衡算法

原理:

复制代码
当总请求数为1时: 1 % 2 =1 对应下标位置为1 ,则获得服务地址为127.0.0.1:8001

当总请求数位2时: 2 % 2 =0 对应下标位置为0 ,则获得服务地址为127.0.0.1:8002

当总请求数位3时: 3 % 2 =1 对应下标位置为1 ,则获得服务地址为127.0.0.1:8001

当总请求数位4时: 4 % 2 =0 对应下标位置为0 ,则获得服务地址为127.0.0.1:8002

如此类推......

手写RoundRobinRule源码

7001/7002集群启动

8001/8002微服务改造

8001/8002 的controller都添加:

java 复制代码
 @GetMapping(value = "/payment/lb")
    public String getPaymentLB()
    {
        return serverPort;
    }

推荐下载代码看

80订单微服务改造

1.ApplicationContextConfig去掉注解@LoadBalanced

2.LoadBalancer接口

3.MyLB

4.修改了OrderController

具体看代码!

测试

启动服务

bash 复制代码
http://localhost/consumer/payment/lb
相关推荐
摇滚侠2 小时前
2025最新 SpringCloud 教程,Gateway-断言-Query,笔记56
笔记·spring cloud·gateway
pp-周子晗(努力赶上课程进度版)3 小时前
Docker入门学习笔记
spring cloud·docker·容器
摇滚侠4 小时前
2025最新 SpringCloud 教程,Gateway-断言-长短写法,笔记55
笔记·spring cloud·gateway
不被AI替代的BOT5 小时前
Spring Cloud Gateway WebFlux 模式架构分析
spring cloud·微服务
小坏讲微服务5 小时前
K8S 部署 Spring Cloud Alibaba 微服务企业实战完整使用
spring cloud·docker·微服务·云原生·容器·kubernetes·k8s
摇滚侠5 小时前
2025最新 SpringCloud 教程,Gateway-路由-工作原理,笔记54
笔记·spring cloud·gateway
摇滚侠5 小时前
2025最新 SpringCloud 教程,Gateway 路由-规则配置,笔记53
笔记·spring cloud·gateway
kong79069286 小时前
Nginx反向代理和负载均衡
nginx·负载均衡·反向代理
ShiLiu_mtx6 小时前
Keepalived,Haproxy负载均衡集群
linux·运维·负载均衡
哈哈哈笑什么21 小时前
高并发分布式Springcloud系统下,使用RabbitMQ实现订单支付完整闭环的实现方案(反向撤销+重试+补偿)
分布式·spring cloud·rabbitmq