springcloud切换负载均衡算法不生效,@RibbonClient与@LoadBalancerClient使用方法

在看尚硅谷的springloud视频时候,跟着视频和下载的脑图资料做的时候,发现由轮询切换随机的负载均衡算法没有生效,看弹幕说什么切换服务名大小写什么的,都没生效,折腾一上午,发现是脑图资料有错误。
在这里插入图片描述
RoundRobinRule()根本就是tmd轮询,而不是随机,不管怎么折腾,都是轮询效果,这里应该是RandomRule()

  @Bean
        public IRule myRule() {
            // 定义为随机
            return new RandomRule();
        }

修改到这里,如果其他跟视频是一样的,那么此时应该是随机效果了,值得注意的是,MySelfRule加不加@Configuration注解都是可以有随机效果的。

另外,网上查到一种说法:视频做法适用于springcloud2020之前版本,2020版本之前是有Ribbon的,但是2020版本之后Springcloud把Ribbon移除了,用LoadBalancer替代了。

这里我贴出LoadBalancer替代方法:

在这里插入图片描述
MySelfRule放在启动类能扫描到的config包下,这里一定要加@Configuration注解
在这里插入图片描述
在使用RestTemplate的配置类上面加注解:

@LoadBalancerClient(name = "CLOUD-PAYMENT-SERVICE",configuration = MySelfRule.class)

在这里插入图片描述

主启动类不加ribbon注解
在这里插入图片描述
访问,是随机效果。

参考链接:
Springcloud2020版之后的Ribbon(LoadBalancer)负载算法转换

spring cloud 2020.0.1 LoadBalancer负载均衡算法切换


版权声明:本文为weixin_42260782原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。