Nacos配置中心避坑指南:灵活配置 server-addr 的坑

Nacos 3.x 优势介绍及接入指南

固定地址配置

在SpringCloud + Nacos的配置中,单环境配置还是比较简单的,application.yml 中配置如下:

bash 复制代码
application.yml 

spring:
  application:
      name: myapp
#  profiles:
#    active: dev
#    active: pre
  config:
    import:
      - nacos:nacos-config-example.properties?refreshEnabled=true
      # yml格式的文件必须加.yml后缀
      - nacos:sysconfig.yml?refreshEnabled=true
  cloud:
    nacos:
      config:
        server-addr: 127.0.0.1:8848 # 换成你的IP
        username: nacos
        password: nacos

环境隔离配置

但是如果需要进行环境隔离,想要在 dev 和 pre 环境中连接到不同的 nacos 服务地址,该如何配置呢? 你可能想到了,分别新建一个 application-dev.yml 和 application-pre.yml 文件,将spring.cloud.nacos.config.server-addr 在各自的环境中分别配置,于是有了下面三个配置文件:

bash 复制代码
application.yml 

spring:
  application:
      name: myapp
  profiles:
#    active: dev
    active: pre
  config:
    import:
      - nacos:nacos-config-example.properties?refreshEnabled=true
      # yml格式的文件必须加.yml后缀
      - nacos:sysconfig.yml?refreshEnabled=true
XML 复制代码
application-dev.yml

spring:
  cloud:
    nacos:
      config:
        server-addr: localhost:8848 # 本地开发环境
        username: nacos
        password: nacos
XML 复制代码
application-pre.yml

spring:
  cloud:
    nacos:
      config:
        server-addr: 192.168.1.221:8848 # 测试环境
        username: nacos
        password: nacos

错误信息:

但是这样配置的话 applicatioin-pre.yml 中的server-addr 并不会生效。此时启动的话会看到如下错误:

14:33:30.475 [main] INFO com.alibaba.nacos.plugin.auth.spi.client.ClientAuthPluginManager -- [ClientAuthPluginManager] Load ClientAuthService com.alibaba.nacos.client.auth.impl.NacosClientAuthServiceImpl success.

14:33:30.476 [main] INFO com.alibaba.nacos.plugin.auth.spi.client.ClientAuthPluginManager -- [ClientAuthPluginManager] Load ClientAuthService com.alibaba.nacos.client.auth.ram.RamClientAuthServiceImpl success.

2026-04-20T14:33:35.373+08:00 INFO 1 --- [heyou-rag] [remote.worker.1] c.a.n.c.remote.client.grpc.GrpcClient : grpc client connection server: 127.0.0.1 ip, serverPort: 9848, grpcTslConfig: {"enableTls":false,"mutualAuthEnable":false,"trustAll":true}

2026-04-20T14:33:35.376+08:00 ERROR 1 --- [heyou-rag] [remote.worker.1] c.a.n.c.remote.client.grpc.GrpcClient : Server check fail, please check server 127.0.0.1, port 9848 is available, error ={}

java.util.concurrent.ExecutionException: com.alibaba.nacos.shaded.io.grpc.StatusRuntimeException: UNAVAILABLE: io exception

at com.alibaba.nacos.shaded.com.google.common.util.concurrent.AbstractFuture.getDoneValue(AbstractFuture.java:594) ~[nacos-client-3.0.3.jar!/:na]

at com.alibaba.nacos.shaded.com.google.common.util.concurrent.AbstractFuture.get(AbstractFuture.java:469) ~[nacos-client-3.0.3.jar!/:na]

at com.alibaba.nacos.common.remote.client.grpc.GrpcClient.serverCheck(GrpcClient.java:234) ~[nacos-client-3.0.3.jar!/:na]

报错原因:

这是因为从 Spring Cloud Alibaba 2025.1.x 版本开始,已不再支持 bootstrap.yml/properties 文件。你需要将配置直接写入 application.yml 或 application.properties 中。 并且推荐通过spring.config.import 方式导入Nacos配置。系统启动时当加载到有 nacos:xxx 的配置文件需要引入时,就会立刻触发 NacosConfigManager 和底层 NacosClient 的初始化,进而建立与 Nacos Server 的连接(包括 gRPC 9848 端口)。这就导致 Nacos客户端(特别是作为配置中心时)的初始化早于 Spring Boot 常规配置文件(如 application-{profile}.yml)的加载。因此它只能使用application.yml文件中的配置,如果没有找到 server-addr ,就会自动采用默认地址:127.0.0.1:8848(当然gRPC端口会+1000,得到9848)

解决方案:

知道了问题的原因那解决方法就简单了,我们可以把 spring.config.import : nacos:xxx 的配置和spring.cloud.nacos.config.server-addr 属性一起分别配置到 application-{profile}.yml 文件中,这样就不会在刚加载主文件时就去初始化 NacosClient了。修改后配置如下:

bash 复制代码
application.yml 

spring:
  application:
      name: myapp
  profiles:
#    active: dev
    active: pre
XML 复制代码
application-dev.yml

spring:
  config:
    import:
      - nacos:nacos-config-example.properties?refreshEnabled=true
      # yml格式的文件必须加.yml后缀
      - nacos:sysconfig.yml?refreshEnabled=true
  cloud:
    nacos:
      config:
        server-addr: localhost:8848 # 本地开发环境
        username: nacos
        password: nacos
XML 复制代码
application-pre.yml

spring:
  config:
    import:
      - nacos:nacos-config-example.properties?refreshEnabled=true
      # yml格式的文件必须加.yml后缀
      - nacos:sysconfig.yml?refreshEnabled=true
  cloud:
    nacos:
      config:
        server-addr: 192.168.1.221:8848 # 测试环境
        username: nacos
        password: nacos
相关推荐
轻刀快马10 小时前
穿透 MQ 专栏 (五):【终局之战】MySQL 和 MQ 的世纪联姻:扒开“分布式事务”的遮羞布
数据库·分布式·消息队列
列星随旋13 小时前
Kafka基础篇
分布式·kafka
Jackyzhe14 小时前
从零学习Kafka:生产者压缩
分布式·学习·kafka
一只普通的码农15 小时前
kafka在windows环境部署
分布式·kafka
Kiyra15 小时前
异步任务不用 Kafka 也行:用 Redis Stream 搭一套轻量级 Producer/Consumer 框架
数据库·人工智能·redis·分布式·后端·缓存·kafka
老码观察17 小时前
分布式系统核心理论与实践:从CAP到工程落地
分布式
赵渝强老师17 小时前
【赵渝强老师】Hadoop的伪分布部署模式
大数据·hadoop·分布式
Mike117.17 小时前
GBase 8c 序列取值在分布式业务里的几个风险点
分布式
淡定一生233317 小时前
spark 3.3+ 之BloomFilter Runtime Filter
大数据·分布式·spark
霑潇雨17 小时前
原生 Zookeeper 实现分布式锁案例
java·分布式·zookeeper·云原生·maven