本文介绍: 修改默认负载均衡策略(Ribbon)
修改方式
- 配置类
- 配置文件
配置类
- 增加配置类:配置类必须拥有 @Configuration 且不能在 @ComponentScan 包下
package com.learning.springcloud.config;
import com.alibaba.cloud.nacos.ribbon.NacosRule;
import com.netflix.loadbalancer.IRule;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
@Configuration
public class RibbonConfig {
/**
* 全局设置负载均衡策略
*
* @return
*/
@Bean
public IRule iRule() {
return new NacosRule();
}
}
- 增加客户端负载配置 @RibbonClients
package com.learning.springcloud;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.web.client.RestTemplateBuilder;
import org.springframework.cloud.client.loadbalancer.LoadBalanced;
import org.springframework.cloud.netflix.ribbon.RibbonClient;
import org.springframework.cloud.netflix.ribbon.RibbonClients;
import org.springframework.context.annotation.Bean;
import org.springframework.web.client.RestTemplate;
@SpringBootApplication
@RibbonClients(value = {@RibbonClient(name = "stock-service", configuration = com.learning.springcloud.config.RibbonConfig.class)
})
public class OrderApplication {
public static void main(String[] args) {
SpringApplication.run(OrderApplication.class); }
@Bean
@LoadBalanced
public RestTemplate restTemplate(RestTemplateBuilder restTemplateBuilder) {
return restTemplateBuilder.build();
}
}
配置文件
-
注释启动类上 @RibbonClien
-
applicaiton.yml 中增加 对应服务的个性化负载均衡策略
server:
port: 8030spring:
application:
name: order-service
cloud:
nacos:
server-addr: 127.0.0.1:8847
discovery:
username: nacos
password: nacos
namespace: 5fe640ca-1ed2-496c-97bd-e0bfb7aef639
stock-service: # 服务名称
ribbon:
NFLoadBalancerRuleClassName: com.alibaba.cloud.nacos.ribbon.NacosRule
原文地址:https://blog.csdn.net/u012516524/article/details/135555433
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.7code.cn/show_56488.html
如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。