修改默认负载均衡策略(Ribbon)

本文介绍了如何在SpringCloud应用中使用Nacos作为配置中心,并配置Ribbon实现服务间负载均衡,包括自定义配置类和在`@RibbonClients`中指定服务的负载均衡策略。
摘要由CSDN通过智能技术生成

修改方式

  • 配置类
  • 配置文件

配置类 

  • 增加配置类:配置类必须拥有 @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


 

  • 9
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Spring Boot整合Ribbon可以实现客户端的负载均衡。下面是整合步骤: 1. 添加依赖:在`pom.xml`文件中添加以下依赖: ```xml <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-ribbon</artifactId> </dependency> ``` 2. 创建Ribbon配置类:创建一个配置类,用于配置Ribbon的相关属性。可以使用`@Configuration`注解进行标注,示例代码如下: ```java import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.cloud.client.loadbalancer.LoadBalanced; import org.springframework.cloud.netflix.ribbon.RibbonClient; @Configuration @RibbonClient(name = "serviceName") // 服务名 public class RibbonConfig { @Bean @LoadBalanced public RestTemplate restTemplate() { return new RestTemplate(); } } ``` 3. 创建服务调用类:创建一个用于调用服务的类,并注入`RestTemplate`对象。示例代码如下: ```java import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.web.client.RestTemplate; @Service public class ServiceInvoker { @Autowired private RestTemplate restTemplate; public String invokeService() { String serviceUrl = "http://serviceName/path"; // 服务名和路径 return restTemplate.getForObject(serviceUrl, String.class); } } ``` 4. 启用Ribbon:在Spring Boot的启动类上添加`@EnableDiscoveryClient`注解,示例代码如下: ```java import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cloud.client.discovery.EnableDiscoveryClient; @SpringBootApplication @EnableDiscoveryClient public class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } } ``` 以上就是Spring Boot整合Ribbon的基本步骤。通过配置Ribbon,可以实现服务的负载均衡,提高系统的性能和可用性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

菜逼の世界

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

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

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

打赏作者

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

抵扣说明:

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

余额充值