解决:Nacos 2.x版本的spring.cloud.nacos.server-addr不生效问题,以及nacos地址一直为localhost:8848问题

1. 错误一:spring.cloud.nacos.server-addr不生效问题

我之前在windows上部署Nacos 2.x,项目正常访问,注册中心和配置中心都正常

这里是windows环境下的bootstrap.properties文件:

spring.application.name=test-nacos
spring.cloud.nacos.server-addr=127.0.0.1:8848 #本地nacos
spring.cloud.nacos.config.file-extension=yml
spring.cloud.nacos.config.namespace=d80c44b5-745f-425d-af0b-bab4bbb12be4
spring.cloud.nacos.config.group=dev

今天想把Nacos 2.x部署到linux上,我选择的是腾讯云的centos7系统,按道理只需要改一下IP即可

这里是linux环境下的bootstrap.properties文件:

spring.application.name=test-nacos
spring.cloud.nacos.server-addr=107.55.111.157:8848 #linux中nacos地址
spring.cloud.nacos.config.file-extension=yml
spring.cloud.nacos.config.namespace=d80c44b5-745f-425d-af0b-bab4bbb12be4
spring.cloud.nacos.config.group=dev

原本以为很简单,结果运行的时候,出现了一下错误:

namingService subscribe failed, properties:NacosDiscoveryProperties{serverAddr='107.55.111.157:8848', endpoint='', namespace='', watchDelay=30000, logName='', service='test-nacos', weight=1.0, clusterName='DEFAULT', group='DEFAULT_GROUP', namingLoadCacheAtStart='false', metadata={preserved.register.source=SPRING_CLOUD}, registerEnabled=true, ip='192.168.137.1', networkInterface='', port=-1, secure=false, accessKey='', secretKey='', heartBeatInterval=null, heartBeatTimeout=null, ipDeleteTimeout=null, failFast=true}

 更多错误日志:解决:Nacos 2.x版本的spring.cloud.nacos.server-addr不生效问题,以及nacos地址一直为localhost:8848问题_第1张图片

 

 从错误日志中,我们发现IP是正常解析的,但是我们设置的namespace,group都没有生效

原因

Nacos 2新版本增加了2个通信端口,如下:

解决:Nacos 2.x版本的spring.cloud.nacos.server-addr不生效问题,以及nacos地址一直为localhost:8848问题_第2张图片

 nacos官方文档也做了详细说明:

因此如果客户端和服务端之前存在端口转发,或防火墙时,需要对端口转发配置和防火墙配置做相应的调整。

我的做法:因为用的是腾讯云,所以直接开放了所有的端口

解决:Nacos 2.x版本的spring.cloud.nacos.server-addr不生效问题,以及nacos地址一直为localhost:8848问题_第3张图片

 我们也可以直接关闭防火墙,就能成功解决了

centos6.5关闭防火墙

centos7关闭防火墙

2. 错误二,nacos地址一直为localhost:8848【Request nacos server failed】

很多人在错误日志中,发现无论怎么改,ip永远都是localhost:8848

解决:Nacos 2.x版本的spring.cloud.nacos.server-addr不生效问题,以及nacos地址一直为localhost:8848问题_第4张图片

 

 原因:

  1. 我们在bootstrap.properties中只配置了spring.cloud.nacos.config.server-addr的值,而Nacos 2.x版本需要的2个端口没有配置,导致spring.cloud.nacos.config.server-addr的值是无效的。
  2. 由于项目中存在nacos依赖,程序会继续找nacos的地址,也就是去加载spring.cloud.nacos.server-addr的值,由于我们没有配置这个值,因此会使用它的默认值localhost:8848,从IDEA也可以看出:解决:Nacos 2.x版本的spring.cloud.nacos.server-addr不生效问题,以及nacos地址一直为localhost:8848问题_第5张图片

综上,就可以看出 ,为什么nacos地址一直显示localhost:8848

注意

① spring.cloud.nacos.config.server-addr的默认值为${spring.cloud.nacos.server-addr}

② 如果你配置了nacos2.x版本的2个端口,那么以下3个配置,任意配置一个即可

--spring.cloud.nacos.server-addr

--spring.cloud.nacos.discovery.server-addr

--spring.cloud.nacos.config.server-addr

你可能感兴趣的:(spring,cloud,alibaba,spring,cloud,alibaba)