Nacos负载均衡

"服务调用者如何选择服务目标实例"

核心原理

服务注册

  • 服务目标者 注册实例 到注册中心

实例订阅

  • 服务调用者通过注册中心 订阅服务目标者,将服务目标者的健康实例推送给消费者

健康检查

  • 注册中心定期对服务目标者提供健康检查(TCP端口、HTTP接口),并剔除不健康的,不可用的实例

负载均衡调用

  • 消费者发起调用时,Nacos Client内置的负载均衡,按算法选择一个实例发起Http调用

  • 默认采用负载均衡算法:轮询


Nacos健康检查机制

  • 默认启用的:默认5秒一次心跳包,服务中心超过15秒没收到心跳则说明不健康,30秒没收到就剔除

  • 服务端主动监测:服务中心向目标实例发起检测请求(TCP/HTTP),未响应就为故障

需要在服务目标者的application.yml中配置数据
XML 复制代码
spring:
  cloud:
    nacos:
      discovery:
        server-addr: 127.0.0.1:8848
        metadata:
          nacos.health.check.url: /actuator/health  # Spring Boot Actuator 健康检查接口
          nacos.health.check.interval: 5000          # 检测间隔 5 秒
          nacos.health.check.timeout: 3000           # 超时时间 3 秒

实操

  • 依赖
java 复制代码
<!-- Nacos 服务发现依赖 -->
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
<!-- Spring Cloud LoadBalancer  -->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-loadbalancer</artifactId>
</dependency>
  • 注入LoadBalanceClient
java 复制代码
//@Autowired
//DiscoveryClient discoveryClient;
@Autowired
RestTemplate restemplate;
@Autowired
LoadBalancerClient loadBalancerClient;
  • 然后给远程调用更换成LoadBalancerClient;
java 复制代码
ServiceInstance choose = loadBalancerClient.choose("service-product");
String url = "http://"+choose.getHost()+":"+choose.getPort()+"/product/"+productId;
Product product = restTemplate.getForObject(url,Product.class);

注解式负载均衡

基于SpringCloud LoadBalancer

@LoadBalanced

只需要给RestTemplate加上这个注解(默认采用负载均衡算法:轮询)

java 复制代码
@Configuration
public class RestTemplateConfig {
    // @LoadBalanced:启用负载均衡,自动从Nacos获取实例并分发流量
    @Bean
    @LoadBalanced
    public RestTemplate restTemplate() {
        return new RestTemplate();
    }
}

这样就可以

java 复制代码
//直接调用服务目标者
String url = "http://service-product/product"+productId;
//service-product会被动态切换
Product product - restemplate.getForObject(url,Product.class);

如果注册中心宕机了,还能使用负载均衡吗

由于有实例缓存

如果调用过一次注册中心的实例列表,就不会再去注册中心,可以使用负载均衡

但是如果没有调用过一次注册中心的实例列表,就不能使用负载均衡了

相关推荐
m0_5493148617 小时前
BIG-IP 介绍 2
tcp/ip·安全·负载均衡·big-ip·f5
m0_5493148618 小时前
BIG-IP 介绍 1
安全·负载均衡·ltm·big-ip·f5
Fᴏʀ ʏ꯭ᴏ꯭ᴜ꯭.20 小时前
HAProxy 自定义错误页面配置指南
运维·负载均衡·web
Gofarlic_oms12 天前
UG/NX浮动许可证池智能配置与负载均衡策略
大数据·运维·网络·人工智能·微服务·负载均衡
七夜zippoe2 天前
客户端负载均衡器深度解析 Spring Cloud LoadBalancer与Ribbon源码剖析
spring cloud·ribbon·负载均衡·loadbalancer·核心机制
岁岁种桃花儿2 天前
LVS、F5、SLB负载均衡全解析:选型与实战指南
kubernetes·负载均衡·企业级负载均衡
翼龙云_cloud2 天前
阿里云云渠道商:弹性伸缩 + 负载均衡:阿里云高可用架构实战
阿里云·架构·云计算·负载均衡
倔强菜鸟2 天前
2026.1.27--负载均衡
运维·负载均衡
市安2 天前
负载均衡入门:HAProxy 双 Web 节点集群配置与验证
linux·运维·服务器·网络·nginx·负载均衡·haproxy
J_liaty3 天前
客户端负载均衡与服务端负载均衡解释与对比
java·运维·负载均衡