SpringBoot-配置加载顺序

目录

前言

样例

内部配置加载顺序

样例

小结


前言

我之前写的配置文件,都是放在resources文件夹,根据当前目录下,优先级的高低,判断谁先被加载。++但实际开发中,我们写的配置文件并不是,都放在一起的,甚至"东一个,西一个"。这时候,就需要,判断谁先被加载++

同一级目录下,优先级:properties >yml >yaml

样例

在resources 文件夹下,application.yml/.yaml配置文件,application.properties配置文件,同时改变端口号,观察最终端口号。

在resources文件夹,properties配置文件优先级大于 yml 配置文件和yaml配置文件,所以呈现的是properties配置文件下修改的端口号

内部配置加载顺序

注意:,当前模块下的resources,java文件夹都是放在classpath(classes文件夹)的目录下

特点(内部配置文件)

1 越靠近当前项目下的配置文件先执行,后面相同的部分,会被覆盖

(如果有一天,你配置信息,配置错误。你可以通过判断原有配置文件的位置,合理的在你当前项目下或当前项目下config目录下,重写一遍配置文件信息,他会覆盖你写错的配置信息)

2 具有config目录 下的配置文件,先执行

样例

题目:通过在不同的目录或文件夹,写配置文件,观察最终的端口号,判断谁的加载顺序最高?

1 当前项目SpringBoot-day01下config目录下,application.properties配置文件 端口号8081

注意:是当前项目下SpringBoot-day01config目录,而不是当前模块dayo2 ,否则会错误

建一个config目录,复制粘贴properties配置文件

2 当前项目下SpringBoot-day01的根目录,application.properties配置文件 端口号8082

复制粘贴properties配置文件

注意:是当前项目下SpringBoot-day01目录,而不是当前模块dayo2 ,否则会错误

3 classpath的根目录config,application.properties配置文件 端口号8083

在当前模块下resources文件夹,建一个config目录,复制粘贴

4在当前模块下 classpath的根目录,application.properties配置文件 端口号8084

点击运行,观察最终端口号结果

说明,在当前项目下config目录下的配置文件加载顺序最高的

如果,修改是相同内容,根据加载顺序,上面的会覆盖下面的。但如果不相同,加载顺序慢的配置文件,依旧会被加载

样例

++我要在day02 模块下,resources文件夹下properties配置文件,修改项目的访问路径++

在day02 模块,编写Controller类

点击运行发现,访问路径发生改变,原本默认的为 /,现在则是 /hello

小结

内部配置,是寄托于IDEA编辑器实现的。对于编写配置(命令,实现功能),我们不仅可以在IDEA中实现,还可以打开黑窗口,输入命令,在外部实现。++例如把spring项目打成jar包,在"黑窗口"运行,大家可以看我SpringBoot配置--Profile这篇博客的命令行参数内容。++

对于内部配置加载顺序,记住三点

1 靠近项目,优先被加载

2 具有config下的文件,在同等情况下,优先被加载

3 同一级目录下,优先级:properties >yml >yaml

相关推荐
一只叫煤球的猫2 小时前
写代码很6,面试秒变菜鸟?不卖课,面试官视角走心探讨
前端·后端·面试
bobz9653 小时前
tcp/ip 中的多路复用
后端
bobz9653 小时前
tls ingress 简单记录
后端
皮皮林5514 小时前
IDEA 源码阅读利器,你居然还不会?
java·intellij idea
你的人类朋友4 小时前
什么是OpenSSL
后端·安全·程序员
bobz9654 小时前
mcp 直接操作浏览器
后端
前端小张同学7 小时前
服务器部署 gitlab 占用空间太大怎么办,优化思路。
后端
databook7 小时前
Manim实现闪光轨迹特效
后端·python·动效
武子康8 小时前
大数据-98 Spark 从 DStream 到 Structured Streaming:Spark 实时计算的演进
大数据·后端·spark
该用户已不存在8 小时前
6个值得收藏的.NET ORM 框架
前端·后端·.net