Springcloud Alibaba自定义负载均衡详解

主要说一下springcloud alibaba 在使用nacos注册中心过程中,请求服务负载均衡的配置方法

引入依赖包 这个依赖包是springcloud在新版本的负载均衡实现,2020版本以上

`

java 复制代码
<dependency>
      <groupId>org.springframework.cloud</groupId>
      <artifactId>spring-cloud-starter-loadbalancer</artifactId>
      <version>XXX</version>
  </dependency>`
默认情况下,负载均衡不需要配置,默认轮询策略,如果我们想改,怎么做呢
先说一下springcloud LoadBalance原理及结构

1、负载均衡器的管理
ReactorLoadBalancer<ServiceInstance> 这就是一个服务绑定的负载均衡器,为每一个服务创建一个负载均衡实体类,实现服务的隔离,虽然我也不知道为啥要这样做

2、工厂来管理负载均衡器

java 复制代码
LoadBalancerClientFactory  

这个工厂相当于管理所有的负载均衡器,你可以通过getInstance方法拿到你的服务名绑定的负载均衡器

3、负载均衡器

java 复制代码
ReactorServiceInstanceLoadBalancer

每一个负载均衡器都实现了这个接口 ,内部定义了choose方法,外部就可以用他的choose方法来找到一个服务

类结构讲完了 怎么自定义一个新的负载均衡器呢

这里就需要一个配置类

java 复制代码
@Configuration
public class FeignForceLoadBalancerConfig {


@Bean
public ReactorLoadBalancer<ServiceInstance> randomLoadBalancer(Environment environment,
    LoadBalancerClientFactory loadBalancerClientFactory) {
    String serviceId = environment.getProperty(LoadBalancerClientFactory.PROPERTY_NAME);
    System.out.println("Init RandomLoadBalancer for service: " + serviceId);
    return new RandomLoadBalancer(
        loadBalancerClientFactory.getLazyProvider(serviceId, ServiceInstanceListSupplier.class),
        serviceId);
}

这里就注册了一个随机策略的负载均衡器,这也是springcloud实现了的,自己定义的话可能需要自己实现接口了

怎么用呢?

上面说了负载均衡器和服务绑定在一起的,所以说还是得声明一下绑定关系

1、随便找个配置类, 加个注解,就说明这个服务走这个负载均衡器

java 复制代码
@LoadBalancerClient(value="service-product",configuration = FeignForceLoadBalancerConfig.class)

不知道为啥他要这么设计,反正挺恶心, 一个负载均衡器和服务绑定,多个负载均衡器就得写多个配置类

这个时候你再在客户端请求service-product服务,那就会走loadbalance,不论你是通过RestTemplate请求还是通过LoadBalanceClient请求服务

附上一个调用链图

复制代码
                        ┌────────────────────────────┐
                        │  @LoadBalancerClient       │
                        │  name="service-product"    │
                        │  config = CustomLBConfig   │
                        └────────────┬───────────────┘
                                     │
         ┌───────────────────────────▼──────────────────────────┐
         │ Spring Context 注入 Bean:                             │
         │ ReactorLoadBalancer<ServiceInstance>                 │
         │ → 例如 RandomLoadBalancer                            │
         │ → 由 CustomLBConfig 中的 @Bean 方法提供              │
         └───────────────────────────┬──────────────────────────┘
                                     │
                  ┌──────────────────▼───────────────────┐
                  │ LoadBalancerClientFactory             │
                  │ - 管理每个服务对应的负载类实例       │
                  │ - 按 serviceId 提供策略               │
                  └──────────────────┬───────────────────┘
                                     │
          ┌──────────────────────────▼──────────────────────────┐
          │ ReactorServiceInstanceLoadBalancer.choose(request) │
          │ (通用选择接口,最终调用你配置的策略类)           │
          └──────────────────────────┬──────────────────────────┘
                                     │
   ┌────────────────────────────────▼────────────────────────────────┐
   │                                                                │
   │    Feign 调用链:                                              │
   │    FeignClient → LoadBalancerFeignClient → choose()           │
   │                                                                │
   │    RestTemplate 调用链:                                       │
   │    RestTemplate + @LoadBalanced → LoadBalancerInterceptor →   │
   │    choose()                                                    │
   │                                                                │
   └────────────────────────────────────────────────────────────────┘
相关推荐
Bug退退退1234 小时前
RabbitMQ 高级特性之死信队列
java·分布式·spring·rabbitmq
guojl9 小时前
RestTemplate使用手册
spring cloud·微服务
guojl9 小时前
RestTemplate原理分析
spring cloud·微服务
booooooty9 小时前
基于Spring AI Alibaba的多智能体RAG应用
java·人工智能·spring·多智能体·rag·spring ai·ai alibaba
极光雨雨9 小时前
Spring Bean 控制销毁顺序的方法总结
java·spring
Ken_11159 小时前
SpringCloud系列(51)--SpringCloud Stream之使用分组解决消息重复消费问题
spring cloud
Spirit_NKlaus10 小时前
解决HttpServletRequest无法获取@RequestBody修饰的参数
java·spring boot·spring
lwb_011811 小时前
SpringCloud——Gateway新一代网关
spring·spring cloud·gateway
lxsy12 小时前
spring-ai-alibaba 1.0.0.2 学习(七)——集成阿里云百炼平台知识库
学习·spring·阿里云·spring-ai·ai-alibaba
程序猿小D12 小时前
[附源码+数据库+毕业论文]基于Spring+MyBatis+MySQL+Maven+jsp实现的电影小说网站管理系统,推荐!
java·数据库·mysql·spring·毕业设计·ssm框架·电影小说网站