springboot 2.4.13 无法从nacos获取配置,但是可以注册到nacos

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了springboot 2.4.13 无法从nacos获取配置,但是可以注册到nacos相关的知识,希望对你有一定的参考价值。

参考技术A springboot 2.4.13,集成了nacos,启动后,nacos注册中心有服务,但是,发现,配置没有生效。于是,开启了一段源码查找的过程。

首先,是pom引入的nacos配置

然后,application.yml添加nacos配置

启动后,发现注册中心有服务,但是,服务的配置不是从nacos配置中心获取的,而是本地的。

查找一下nacos源码,找到nacos配置自动注入那块儿:

然后发现,是这个NacosPropertySourceLocator实现的配置导入的

查询源码,可以发现,相关的配置,是通过这个方法,加载的,这个方法是总入口。

于是,尝试加断点,查看配置信息,看看为什么没有导入配置。然而,程序根本就没有进入这个方法里面!!!

根据接口实现,可以发现NacosPropertySourceLocator 是PropertySourceLocator的实现类,这个方法的调用执行,不是nacos自己去做的,而是通过spring去做的。

spring cloud 通过BootstrapApplicationListener,以监听器的方式,通过监听springboot启动过程中的事件,通过onApplicationEvent方法处理事件,导入spring cloud相关配置。

通过加断点,可以发现,这里的方法bootstrapEnabled()返回值是false,直接就不执行后续的加载了。

因此,需要保证bootstrapEnabled返回值是true。

查看PropertyUtils源码,可以发现,需要配置项 spring.cloud.bootstrap.enabled=true 并且存在 org.springframework.cloud.bootstrap.marker.Marker 类的时候,spring cloud 才会去加载spring cloud的配置。

因此,pom中需要添加marker所在的组件依赖:

此时,需要在 bootstrap.yml 中添加spring cloud配置:

(至于为什么是bootstrap.yml而不是application.yml,这又是另一个问题了)

有了上面的配置,程序启动后,就能正常的从nacos配置中心获取配置了。

以上是关于springboot 2.4.13 无法从nacos获取配置,但是可以注册到nacos的主要内容,如果未能解决你的问题,请参考以下文章

2019-10-31 spring Cloud 无法注册到nacos问题

从SpringBoot生命周期来看服务注册到Eureka/Nacos的时机

启动springboot项目连接nacos控制台报错com.alibaba.nacos.api.exception.NacosException: dataId invalid

SpringBoot Nacos 读取不到配置(版本2.4.6)

启动springboot项目连接nacos控制台报错com.alibaba.nacos.api.exception.NacosException: dataId invalid

Nacos学习笔记 Nacos整合SpringBoot流程