Ribbon调用原理分析,负载均衡策略以及自定义负载算法

本文深入探讨了Ribbon的调用原理,分析了其负载均衡策略,包括轮询和随机等默认算法。同时,展示了如何在不依赖Eureka的情况下单独使用Ribbon进行负载均衡,并详细讲解了如何自定义负载均衡算法,强调了配置类的位置和注解的使用。通过示例代码,演示了自定义负载算法的注入和启用。文章结尾提醒读者注意@RibbonClient注解的使用细节。
摘要由CSDN通过智能技术生成

LD is tigger forever,CG are not brothers forever, throw the pot and shine.
Modesty is not false, solid is not naive, treacherous but not deceitful, stay with good people, and stay away from poor people.
talk is cheap, show others the code,Keep progress,make a better result.

目录

概述

架构特性

设计思路

实现思路分析

Ribbon负载均衡策略

在这里插入图片描述

拓展实现

单独使用Ribbon

  因为往往Ribbon配合Eureka使用的,往往也有第三方服务没有注册到Eureka Server,但也部署了多个实例,也需要进行负载均衡,这时可以在服务消费者的配置文件中进行如下方式配置,实现负载均衡

自定义负载均衡算法

这个自定义的类不能放在@ComponentScan所扫描的当前包以及子包下,否则我们自定义的这个配置类就会被所有的Ribbon客户端所共享,也就是我们达不到特殊化指定的目的了。

因为主启动类已经有ComponentScan,这个注解了,所以说不能放在和主启动类同包下。

注入bean

如果想使用某个自定义算法则注入到bean中即可。

/**
 * 自定义负载均衡算法
 */
// @Configuration -- 通过注解@RibbonClient为特定的服务配置负载均衡策略,
//                   这时候该注解需去掉,否则会执行两次RandomRule()
public class MySelfRule {
     @Bean
    public IRule myRule() {
        //return new RoundRobinRule();//轮询算法
        //return new RandomRule();//随机算法
        return new RandomRule_ZY();
    }
 
}

添加ribbon注解

@SpringBootApplication
@EnableEurekaClient
@RibbonClient(name = "MICROSERVICECLOUD-DEPT", configuration = MySelfRule.class)
public class DeptConsumer80_App {
    public static void main(String[] args) {
        SpringApplication.run(DeptConsumer80_App.class, args);
    }
}

特别注意的是@RibbonClient(name = “MICROSERVICECLOUD-DEPT”, configuration = MySelfRule.class)
name指定针对哪个服务 进行负载均衡,而configuration指定负载均衡的算法具体实现类

相关工具如下:

实验效果:(解决思路)

分析:

小结:

主要讲述了一些Ribbon的负载均衡,里面有许多不足,请大家指正~

参考资料和推荐阅读

1.链接: 参考资料.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

执于代码

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值