栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

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

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

解决: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

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/703164.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号