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
相关推荐
喂完待续1 天前
【序列晋升】28 云原生时代的消息驱动架构 Spring Cloud Stream的未来可能性
spring cloud·微服务·云原生·重构·架构·big data·序列晋升
荣光波比1 天前
Nginx 实战系列(四)—— Nginx反向代理与负载均衡实战指南
运维·nginx·云计算·负载均衡
惜.己1 天前
Docker启动失败 Failed to start Docker Application Container Engine.
spring cloud·docker·eureka
chenrui3102 天前
Spring Boot 和 Spring Cloud: 区别与联系
spring boot·后端·spring cloud
喂完待续2 天前
【序列晋升】29 Spring Cloud Task 微服务架构下的轻量级任务调度框架
java·spring·spring cloud·云原生·架构·big data·序列晋升
麦兜*3 天前
MongoDB 性能调优:十大实战经验总结 详细介绍
数据库·spring boot·mongodb·spring cloud·缓存·硬件架构
半梦半醒*4 天前
ansible阶段练习题
linux·运维·自动化·ansible·负载均衡·运维开发
小马爱打代码4 天前
Spring Cloud LoadBalancer 核心原理
spring cloud
小马爱打代码5 天前
Spring Cloud Eureka 核心原理
spring cloud·eureka
AAA修煤气灶刘哥5 天前
后端哭晕:超时订单取消踩过的坑,延迟消息这么玩才对!
后端·spring cloud·rabbitmq