前言
Spring Cloud 构建于 Spring Boot 之上,在 Spring Boot 中有两种上下文,一种是 bootstrap
,另外一种是 application
。
1、bootstrap.yml 和 application.yml 区别
bootstrap.yml
和 application.yml
都可以用来配置参数。
bootstrap.yml
bootstrap.yml
用来程序引导时执行,应用于更加早期配置信息读取。可以理解成系统级别的一些参数配置,这些参数一般是不会变动的。
application.yml
application.yml
可以用来定义应用级别的, 应用程序特有配置信息,可以用来配置后续各个模块中需使用的公共参数等。如果搭配 配置中心(spring-cloud-config or nacos) 使用, application.yml
里面定义的文件可以实现动态替换。
2、加载顺序
若application.yml
和 bootstrap.yml
在同一目录下:bootstrap.yml
先加载,application.yml
后加载
bootstrap.yml
用于application上下文的引导阶段。bootstrap.yml
由父Spring ApplicationContext加载。
3、属性覆盖问题
启动上下文时,Spring Cloud 会创建一个 Bootstrap Context,作为 Spring 应用的 Application Context 的父上下文。
初始化的时候,Bootstrap Context 负责从外部源加载配置属性并解析配置。这两个上下文共享一个从外部获取的 Environment。
但是若 application.yml
与 bootstrap 存在相同的配置项,还是会覆盖 bootstrap,而 application.yml
里面的内容可以动态替换。
4、bootstrap.yml典型的应用场景
- 当使用 Spring Cloud Config Server (或者Spring Cloud Alibaba Nacos)配置中心时,这时必须将 spring.application.name 和 spring.cloud.config.server.git.uri(或者spring.cloud.nacos.config)配置在 bootstrap.yml 配置文件中,添加连接到配置中心的配置属性来加载外部配置中心的配置信息
- 一些固定不变的属性
- 一些加密/解密的场景