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
相关推荐
毕小宝2 小时前
Nacos 3.2.0 升级问题汇总
nacos
nashane3 小时前
HarmonyOS 6.0 分布式相机实战:调用远端设备摄像头与AI场景识别(API 11+)
分布式·数码相机·harmonyos·harmonyos 5
炘爚6 小时前
C++实现分布式集群聊天服务器
服务器·c++·分布式
gududexiao6 小时前
RabbitMQ 的介绍与使用
分布式·rabbitmq·ruby
Kristrina7 小时前
RabbitMQ高级特性----生产者确认机制
分布式·rabbitmq
渔民小镇7 小时前
5 分钟搭建桌游服务器:Room 模块 + 领域事件实战
java·运维·服务器·分布式·游戏
weixin_419658317 小时前
RabbitMQ 介绍
分布式·rabbitmq
未秃头的程序猿7 小时前
从“拆东墙补西墙”到“最终一致”:分布式事务在Spring Boot/Cloud中的破局之道
分布式·后端·spring cloud
iOS妖狐小北7 小时前
RabbitMQ之交换机
分布式·rabbitmq·ruby