nacos bootstrap.yml 和 spring.config.import 加载配置的流程区别

相关依赖

springboot:2.7.15

nacos:2.2.3

bootstrap.yml加载方式

加载流程如下图所示

从图中可以看出,:

1.bootstrap.yml 的加载是在 BootstrapApplicationListener.onApplicationEvent 接收到 ApplicationEnvironmentPreparedEventEvent 事件后另起一个 SpringApplication 触发的。

2.之后在初始的 SpringApplication 中 通过 EnvironmentPostProcessorApplicationListener.
onApplicationEnvironmentPreparedEvent 接收到 ApplicationEnvironmentPreparedEventEvent 事件加载 application.yml

  1. nacos 配置的加载是在 SpringApplication.prepareContext 的时候进行加载的

spring.config.import 加载方式

加载流程如下图所示

从图中可以看出,application.yml 和 nacos 配置的都是在 EnvironmentPostProcessorApplicationListener.
onApplicationEnvironmentPreparedEvent 接收到 ApplicationEnvironmentPreparedEventEvent 事件后加载的

结论:

1.spring.config.import 方式加载 application.yml 和 nacos 配置都是在 ApplicationEnvironmentPreparedEventEvent 期间

  1. bootstrap.yml 方式加载 application.yml 和 bootstrap.yml 是在 ApplicationEnvironmentPreparedEventEvent 期间,但是 nacos 配置的加载是在 SpringApplication.prepareContext 期间。

启动期间输出本地yml配置的方式

目前想到的是用于查看 nacos 的 namespace 和 ip,主要是当有多个地方都有配置nacos的时候,可以通过直接输出 ip 和 namespace 识别是否配置正确。

复制代码
public static void main(String[] args) {
	SpringApplication springApplication = new SpringApplication(SimAppExperimentApplication.class);
	springApplication.addListeners(new ConfigLog());
	springApplication.run(args);
}

  
public static class ConfigLog implements ApplicationListener<ApplicationEnvironmentPreparedEvent> {

	@Override
	public void onApplicationEvent(ApplicationEnvironmentPreparedEvent event) {
		Environment environment = event.getEnvironment();
		System.out.println("nacos 配置中心ip:"+environment.getProperty("spring.cloud.nacos.config.server-addr"));
		System.out.println("nacos 配置中心namespace:"+environment.getProperty("spring.cloud.nacos.config.namespace"));
    }

}

基于 bootstrap.yml 的配置方式只能输出本地 bootstrap.yml 和 application.yml 的配置,无法输出naocs 中的配置里的

基于spring.config.import 方式连 nacos 中的配置也能输出

相关推荐
axinawang2 分钟前
spring boot 整合redis
spring boot·redis·bootstrap
Alt.97 分钟前
SpringMVC基础一(SpringMVC运行原理)
数据库·spring·mvc
LCY1331 小时前
docker 常用指令整理
java·后端·spring
影子信息1 小时前
vue 走马灯 纵向滚动
前端·css
叶浩成5201 小时前
arco-design-vue:给<a-table>组件每一行添加data-id属性,并根据id数组是否包含此行id进行样式处理
前端·javascript·vue.js
我自纵横20231 小时前
Vue 3 中 ref 与 reactive 的对比
前端·javascript·vue.js·typescript·前端框架·html5
lvbb661 小时前
react动态路由
前端·react.js·前端框架
体育分享_大眼1 小时前
体育API架构设计实战:如何打造高并发赛事数据服务?
前端·后端
DogerW1 小时前
前端开发入门指南(写给后端同学)
前端