解决: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}
更多错误日志:
从错误日志中,我们发现IP是正常解析的,但是我们设置的namespace,group都没有生效
原因
Nacos 2新版本增加了2个通信端口,如下:
nacos官方文档也做了详细说明:
因此如果客户端和服务端之前存在端口转发,或防火墙时,需要对端口转发配置和防火墙配置做相应的调整。
我的做法:因为用的是腾讯云,所以直接开放了所有的端口
我们也可以直接关闭防火墙,就能成功解决了
centos6.5关闭防火墙
centos7关闭防火墙
2. 错误二,nacos地址一直为localhost:8848【Request nacos server failed】
很多人在错误日志中,发现无论怎么改,ip永远都是localhost:8848
原因:
- 我们在bootstrap.properties中只配置了spring.cloud.nacos.config.server-addr的值,而Nacos 2.x版本需要的2个端口没有配置,导致spring.cloud.nacos.config.server-addr的值是无效的。
- 由于项目中存在nacos依赖,程序会继续找nacos的地址,也就是去加载spring.cloud.nacos.server-addr的值,由于我们没有配置这个值,因此会使用它的默认值:localhost:8848,从IDEA也可以看出:
综上,就可以看出 ,为什么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
转载请注明:解决:Nacos 2.x版本的spring.cloud.nacos.server-addr不生效问题,以及nacos地址一直为localhost:8848问题 | 胖虎的工具箱-编程导航