背景:

由于目前网上对于springboot配置文件的加载问题,存在着各种不同的说法。所以导致自己不敢确定到底何种结论才是真正正确的,故专门花费了一些时间进行亲自验证。

验证:

在经过自己对配置文件的加载问题进行验证后,发现所谓配置文件的优先级并不一定是固定不变的,而是会受一些前提条件的影响。下面将对bootstrap.properties、bootstrap.yml、application.properties、application.yml这四种我们可能使用到的配置文件的加载优先级问题进行详细的说明(此处以springCloud微服务项目为背景,不然单纯的springBoot项目是不会加载bootstrap配置文件的,且以下说明默认配置文件都是在同一目录)。

一.非活动的profile

首先,在默认的情况下也就是不存在活动的profile(即不指定spring.profiles.active=?)时,四种文件的加载优先级依次为bootstrap.properties -> bootstrap.yml -> application.properties -> application.yml。感兴趣可以在源码上打断点可以得知配置文件的加载分为两次,如图所示:
第一次是bootstrap(.properties/.yml)的加载:

以此得出加载优先级bootstrap.properties -> bootstrap.yml

第二次是application(.properties/yml)的加载:

以此得出application.properties -> application.yml。
总结:bootstrap的配置先于application的配置加载,同时.properties的加载又先于.yml的加载,即加载优先级bootstrap.properties -> bootstrap.yml -> application.properties -> application.yml。
需要注意的是:
1.当同一个配置属性在bootstrap.properties和bootstrap.yml文件中都存在时,那么properties中的配置会被加载,而忽略yml文件中的配置(即优先级高的配置覆盖优先级低的配置),不同配置相互互补。此处application(.properties/yml)同理。
2.但当同一配置在bootstrap.properties和application.properties中都存在时,那么虽然优先加载bootstrap.properties但是会被applicatioin.properties中的配置覆盖,此时则变成了低优先级覆盖高优先的配置,所以网上很多文章所说的高优先级覆盖低优先级其实是不严谨的。
3.不同的配置会进行互补操作,即SpringBoot会读取全部的配置文件,加载所有不同的配置项,汇成一个总的配置。

二、活动的profile

例如在指定了spring.profiles.active=dev/test/prod此类时,即有了活动的profile时,加载优先级便会发生变化此时活动的优先级最高,还是直接上图:

指定profile为dev

配置文件如上
看一下加载顺序变成怎么样的了,同样第一次先加载bootstrap:

第二次加载application:

综上此时的加载优先级变为了bootstrap-dev.yml -> bootstrap.properties -> application-dev.yml ->application.properties。且同属性配置的覆盖问题和之前一样,在同为bootstrap或同为application的情况下,优先级高的覆盖优先级低的。但当同时存在bootstrap和application时后者仍会覆盖前者中的配置。
举例1:假如此时只有bootstrap-dev.yml 和bootstrap.properties且存在相同配置,则使用bootstrap-dev.yml中的配置,此时遵循高优先级覆盖低优先级。
举例2:假如此时有bootstrap-dev.yml 、bootstrap.properties及application.properties且存在相同配置,则使用application.properties中的配置,遵循application覆盖bootstrap原则,同样此时变成了低优先级覆盖高优先级。

三、使用外部配置

如项目使用nacos做配置中心,则存在相同配置时以nacos中配置为主(在没有开启本地覆盖nacos远程配置的情况下),nacos中的配置将会覆盖一切本地相同的配置,不同配置可以和本地进行互补。

扩展nacos开启本地覆盖远程配置

如果需要启动参数或者本地配置覆盖远程配置,那么需要在远程配置里配置上允许重写:
spring.cloud.config.allowOverride=true
但这是不够的,尽管它开启了总开关,但是还有两个默认的小开关卡住了。
应同时添加如下配置:
spring.cloud.config.overrideNone=true
spring.cloud.config.overrideSystemProperties=false
第一个开关是远端不覆盖本地?true 是的不覆盖。
第二个开关是远端是否覆盖系统配置?false 不覆盖。 (默认为true 覆盖)
请注意,第一个小开关包括第二个。
overrideNone = true的话会开启所有包括本地配置和系统配置并忽略掉overrideSystemProperties配置。
如果只想开启overrideSystemProperties,那么就是overrideNone = false,overrideSystemProperties=false。

springBoot项目配置文件加载优先级及同配置覆盖问题相关推荐

  1. springboot配置文件加载顺序_「SpringBoot系列」配置文件加载优先级解析

    SpringBoot提供了外部分配置功能,可以使用属性文件(properties).YAML(yml)文件.环境变量和命令行参数来进行处部参数配置,并t以特定的顺序来处理配置,以便于允许合理的覆盖值. ...

  2. Spring Boot的配置文件加载优先级

    基于Spring Boot 2.x详细介绍了Spring Boot的配置文件的加载优先级. 文章目录 1 总体优先级 2 内部配置优先级 3 bootstrap和application的优先级 1 总 ...

  3. springboot多环境加载yml和logback配置

    大家好,我是烤鸭: 这是一篇关于springboot多环境加载yml和logback配置文件. 环境: 开发工具 idea(推荐)/eclipse(对yml支持不好) jdk  1.8 springb ...

  4. SpringBoot之配置文件加载位置

    1.简介 SpringBoot启动会扫描以下位置的application.properties或者application.yml文件作为SpringBoot的默认配置文件 优先级由高到低,高优先级的配 ...

  5. 配置文件加载优先级和外部配置文件加载||IDEA外部配置文件无法加载

    1,项目内部配置文件 spring boot 启动会扫描以下位置的 application.properties 或者 application.yml 文件作为 Spring boot 的默认配置文件 ...

  6. SpringBoot的配置文件加载顺序和使用方式

    1.bootstrap.properties bootstrap.properties 配置文件是由"根"上下文优先加载,程序启动之初就感知 如:Spring Cloud Conf ...

  7. SpringBoot项目网页加载出现Whitelabel Error Page

     运行SpringBoot项目之后,在浏览器输入localhost:8081 ,出现如下界面, 1.有index.html文件 2.端口没有写错  到后面发现pom.xml导错springboot依赖 ...

  8. 3springboot:springboot配置文件(外部配置加载顺序、自动配置原理,@Conditional)

    1.外部配置加载顺序 SpringBoot也可以从以下位置加载配置: 优先级从高到低 高优先级的配置覆盖低优先级的配置,所有的配置会形成互补配置  1.命令行参数 所有的配置都可以在命令行上进行指定 ...

  9. spring boot:从零开始搭建一个项目 - day 7 springboot devtools热加载+MybatisPlus配置+kisso从入门到放弃

    spring boot:从零开始搭建一个项目 - day 7 springboot devtools热加载+MybatisPlus配置+kisso从入门到放弃 一.springboot devtool ...

最新文章

  1. Ret2Libc(2) (有system、无‘/bin/sh’)绕过NX、ASLR
  2. python写入数据库_Python pymysql写入数据库报错
  3. 操作篇 ###rip协议学习和理解##
  4. AOP (面向切面编程)
  5. 【算法实践】搜狗信息流推荐算法交流.pdf(附下载链接)
  6. 对一道if-else相关的程序题的简单分析
  7. 读《我在未来等你》有感
  8. 基于鸢尾花卉数据集的Fisher分类器设计
  9. Windows 0day成功验证之ETERNALBLUE 本帖由春秋首发~作者:神风 @春秋文阁负责人 方程式又一波0day【该贴有工具】:https://bbs.ichunqiu.com/thr
  10. yaw公式_3D 视角旋转矩阵 yaw pitch roll (pan, tilt)的数学计算
  11. 【深入浅出imx8企业级开发实战 | 01】imx8qxp yocto工程构建指南
  12. AutoCAD2004下载AutoCAD2004中文版安装教程
  13. python123随机密码生成_Python生成对应随机密码文件
  14. vue表格根据属性值设置背景颜色、vue表格设置鼠标悬浮背景颜色、vue表格的隔行变色修改背景颜色
  15. Linux如何安装pcre
  16. linux运行directory,我在linux里用命令出来is a directory是怎么回事
  17. 吉大计算机科学与技术网安,李嘉菲-吉林大学计算机科学与技术学院
  18. 微信小程序:uu传书
  19. 读取Java源文件中字段的注释当做Swagger的字段描述
  20. 报错 Error from server (InternalError): an error on the server (““) has prevented the request from suc

热门文章

  1. 大春天的,兰州竟然下了一场大雪!
  2. MySQL常用基础命令行
  3. python调用java的方法
  4. 怎么修改图片长宽尺寸?如何用电脑修改照片尺寸?
  5. 倍加福对射型光电传感器 GD18/GV18/115/120 产品阐述
  6. 【有利可图网】PS教程:用PS中的3D功能合成一幅比较有视觉冲击创意海报!
  7. 论文复现《Deep Landscape Forecasting for Real-time Bidding Advertising》
  8. python 读取文件名 指定编码_Python 文件读写与编码解读
  9. 终于!马斯克 Neuralink 获得 FDA 批准,可首次进行人体实验
  10. 网络古风音乐文化功能研究