关于nacos的配置获取失败及服务发现问题的排坑记录
nacos
Nacos是由阿里巴巴开源的服务治理中间件,集成了动态服务发现、配置管理和服务元数据管理功能,广泛应用于微服务架构中,简化服务治理过程。
项目地址:https://gitcode.com/gh_mirrors/na/nacos
免费下载资源
·
nacos配置更新未能获取到导致启动报错
排查思路:
1、是否添加了nacos的启动pom依赖
参考:
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>
2、是否在配置文件中添加了对应的配置
排查配置文件中的配置,注意配置与代码中注入的格式保持一致
3、如果是热更,检查是否开启了热更
参考配置:
# 开启监听和自动刷新,动态感知配置变化,默认值:true
spring.cloud.nacos.config.refresh-enabled=true
可参考对应的代码配置:
- bean上有注解@NacosRefresh,则会自动刷新
- 使用了@Component注解,则会自动刷新
- 如果都没有效果,bean上加 @RefreshScope注解,配置文件中配置refresh: true,一定会生效
注意spring.cloud.nacos.config.extension-configs配置格式,参考:
spring:
cloud:
nacos:
config:
file-extension: yml
server-addr:
namespace:
group: DEFAULT_GROUP
# 注意下面这行配置
extension-configs:
- data-id: base.yml
refresh: true
- data-id: mysqlMaster.yaml
refresh: true
refresh-enabled: true
4、检查nacos中的配置文件名称、命名空间是否一致,以及自己本地配置的nacos的地址分组等是否正确
bootstrap.yml中配置了地址、命名空间、分组等,参考如下:
cloud:
nacos:
config:
server-addr: xx.xx.xxx:8888
file-extension: yaml
#命名空间
namespace: wwb
#分组
group: DEFAULT_GROUP
#从nacos读取配置项的超时时间
timeout: 5000
#长轮训超时时间
config-long-poll-timeout: 1000
#重试时间
config-retry-time: 100000
#长轮询重试次数
max-retry: 3
#开启监听和自动刷新
refresh-enabled: true
enable-remote-sync-config: true
特别注意,namespace的配置对应的是nacos中配置文件的ID,如图:
5、本地配置迁移nacos时需要移除本地配置
本地的一些properties配置文件需要移除,否则影响启动时的配置加载
本地服务启动,nacos上未发现服务的排查经验
1、检查本地bootstrap.yml中配置的nacos地址、命名空间、分组 是否与nacos上自己预期的一致
2、检查命本地bootstrap.yml中配置的命名空间是否匹配了nacos中配置文件的ID
3、检查Nacos中配置文件的内容是否正确
参考:
spring:
cloud:
nacos:
discovery:
# Nacos的服务注册地址,可以配置多个,逗号分隔
server-addr: xxx.xxx.xxx:8888
# 服务注册到Nacos上的名称,一般不用配置
#service: coupon-customer-serv
# nacos客户端向服务端发送心跳的时间间隔,时间单位其实是ms
heart-beat-interval: 5000
# 服务端没有接受到客户端心跳请求就将其设为不健康的时间间隔,默认为15s
# 注:推荐值该值为15s即可,如果有的业务线希望服务下线或者出故障时希望尽快被发现,可以适当减少该值
heart-beat-timeout: 20000
# [注意] 这个IP地址如果更换网络后变化,会导致服务调用失败,建议先不要设置
# ip: 172.0.0.888
# 元数据部分 - 可以自己随便定制
#metadata:
# mydata: abc
# 客户端在启动时是否读取本地配置项(一个文件)来获取服务列表
# 注:推荐该值为false,若改成true。则客户端会在本地的一个文件中保存服务信息,当下次宕机启动时,会优先读取本地的配置对外提供服务。
naming-load-cache-at-start: false
# 创建不同的集群
#cluster-name: Cluster-A
# 命名空间ID,Nacos通过不同的命名空间来区分不同的环境,进行数据隔离,
# 服务消费时只能消费到对应命名空间下的服务。
# [注意]需要在nacos-server中创建好namespace,然后把id copy进来
namespace: wwb
# [注意]两个服务如果存在上下游调用关系,必须配置相同的group才能发起访问
group: DEFAULT_GROUP
# 向注册中心注册服务,默认为true
# 如果只消费服务,不作为服务提供方,倒是可以设置成false,减少开销
register-enabled: true
特别关注:server-addr、namespace、group的这三个配置
GitHub 加速计划 / na / nacos
29.84 K
12.75 K
下载
Nacos是由阿里巴巴开源的服务治理中间件,集成了动态服务发现、配置管理和服务元数据管理功能,广泛应用于微服务架构中,简化服务治理过程。
最近提交(Master分支:3 个月前 )
4334cd16
* Support custom client configuration timeout.(#12748)
* Add UT.(#12748) 24 天前
b04d2266
28 天前
更多推荐
已为社区贡献1条内容
所有评论(0)