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 中的配置也能输出

相关推荐
蓝婷儿27 分钟前
每天一个前端小知识 Day 28 - Web Workers / 多线程模型在前端中的应用实践
前端
琹箐27 分钟前
Ant ASpin自定义 indicator 报错
前端·javascript·typescript
小小小小小惠31 分钟前
Responsetype blob会把接口接收的二进制文件转换成blob格式
前端·javascript
爱电摇的小码农31 分钟前
【深度探究系列(5)】:前端开发打怪升级指南:从踩坑到封神的解决方案手册
前端·javascript·css·vue.js·node.js·html5·xss
kymjs张涛1 小时前
零一开源|前沿技术周报 #7
android·前端·ios
爱编程的喵1 小时前
React入门实战:从静态渲染到动态状态管理
前端·javascript
Tttian6221 小时前
npm init vue@latestnpm error code ETIMEDOUT
前端·vue.js·npm
患得患失9491 小时前
【前端】【组件库开发】【原理】【无框架开发】现代网页弹窗开发指南:从基础到优化
前端
运维咖啡吧1 小时前
给朋友们分享个好消息 7天时间23.5k
前端·程序员·ai编程
元气小嘉2 小时前
前端技术小结
开发语言·前端·javascript·vue.js·人工智能