SpringCloud 2023 LoadBalancer介绍、使用、获取服务列表原理、负载均衡算法

目录

  • [1. 介绍](#1. 介绍)
  • [2. 使用](#2. 使用)
  • [3 获取服务列表原理](#3 获取服务列表原理)
  • [4. 负载均衡算法](#4. 负载均衡算法)

1. 介绍

功能:

  1. 提供客户端的负载均衡算法,将请求均摊到多个服务器上。
  2. 属于客户端负载均衡(Nginx属于服务端负载均衡),会将服务列表缓存到JVM本地,然后客户端自己选择请求服务器
  3. 支持Spring Web Flux的WebClient

2. 使用

基本使用可以参考Nacos之SpringCloud集成Nacos注册中心

3 获取服务列表原理

底层是通过DiscoveryClient动态获取所有上线的服务列表。伪代码如下:

Java 复制代码
@RestController
public class OrderController {

    @Autowired
    private DiscoveryClient discoveryClient;

    @GetMapping("/nacos/getNacosAllServiceInfo")
    public String getNacosAllServiceInfo() {
        List<String> serviceNames = discoveryClient.getServices();
        Map<String, Object> serviceMap = new HashMap<>();
        for (String serviceName : serviceNames) {
            List<ServiceInstance> serviceInstances = discoveryClient.getInstances(serviceName);
            List<Map<String,String>> serviceInstanceInfos = new ArrayList<>();
            for(ServiceInstance serviceInstance: serviceInstances) {
                Map<String, String> serviceInstanceMap = new HashMap<>();
                serviceInstanceMap.put("serviceId", serviceInstance.getServiceId());
                serviceInstanceMap.put("instanceId", serviceInstance.getInstanceId());
                serviceInstanceMap.put("host", serviceInstance.getHost());
                serviceInstanceMap.put("port", String.valueOf(serviceInstance.getPort()));
                serviceInstanceMap.put("uri", serviceInstance.getUri().toString());
                
                serviceInstanceInfos.add(serviceInstanceMap);
            }
            serviceMap.put(serviceName, serviceInstanceInfos);
        }

        return serviceMap.toString();

    }


}

访问http://localhost:8002/nacos/getNacosAllServiceInfo,返回的数据如下:

复制代码
{orderment=[{instanceId=192.168.163.1#8002#DEFAULT#DEFAULT_GROUP@@orderment, port=8002, host=192.168.163.1, serviceId=orderment, uri=http://192.168.163.1:8002}], payment=[{instanceId=192.168.163.1#8001#DEFAULT#DEFAULT_GROUP@@payment, port=8001, host=192.168.163.1, serviceId=payment, uri=http://192.168.163.1:8001}]}

4. 负载均衡算法

  • 默认的轮询算法RoundRobinLoadBalancer: rest接口第几次请求数 % 服务器集群总数量 = 实际调用服务器位置下标,每次服务重启动后rest接口计数从1开始
  • 同时提供了随机算法RandomLoadBalancer的实现。切换代码如下。说明:
    • 实现了LoadBalancerConfig,会使默认的RoundRobinLoadBalancer失效
    • 要向哪个服务发送请求,就要在@LoadBalancerClient@LoadBalancerClients中定义
Java 复制代码
//@LoadBalancerClient(value = "payment1", configuration = LoadBalancerConfig.class)
@LoadBalancerClients({
        @LoadBalancerClient(value = "payment1", configuration = LoadBalancerConfig.class),
        @LoadBalancerClient(value = "payment2", configuration = LoadBalancerConfig.class),
})
public class LoadBalancerConfig {

    @Bean
    ReactorLoadBalancer<ServiceInstance> randomLoadBalancer(Environment environment,
                                                            LoadBalancerClientFactory loadBalancerClientFactory) {
        String name = environment.getProperty(LoadBalancerClientFactory.PROPERTY_NAME);
        return new RandomLoadBalancer(loadBalancerClientFactory
                .getLazyProvider(name, ServiceInstanceListSupplier.class),
                name);
    }
}
相关推荐
追风筝的人er4 天前
企业管理系统如何实现自定义首页与千人千面?RuoYi Office 给出了完整方案
vue.js·spring boot·spring cloud
三水不滴4 天前
利用SpringCloud Gateway 重试 + 降级解决第三方接口频繁超时问题,提升性能
经验分享·笔记·后端·spring·spring cloud·gateway
知识即是力量ol5 天前
微服务架构:从入门到进阶完全指南
java·spring cloud·微服务·nacos·架构·gateway·feign
Java水解5 天前
【Spring Cloud】优雅实现远程调用-OpenFeign
后端·spring cloud
Remember_9935 天前
SpringCloud:Nacos注册中心
java·开发语言·后端·算法·spring·spring cloud·list
J_liaty5 天前
Spring Cloud 微服务面试高频题
spring cloud·微服务·面试
西门吹雪分身5 天前
SpringCloudGateway过滤器之RequestRateLimiterGatewayFilterFactory
java·redis·spring cloud
vx_Biye_Design5 天前
【关注可免费领取源码】云计算及其应用网络教学系统--毕设附源码35183
java·spring·spring cloud·servlet·eclipse·云计算·课程设计
Coder_Boy_6 天前
Java后端核心技术体系全解析(个人总结)
java·开发语言·spring boot·分布式·spring cloud·中间件
悠闲蜗牛�6 天前
Kubernetes从零到集群:本地Minikube环境搭建与Spring Cloud微服务运维实战
spring cloud·微服务·kubernetes