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

相关推荐
雨中飘荡的记忆26 分钟前
大流量下库存扣减的数据库瓶颈:Redis分片缓存解决方案
java·redis·后端
开心就好20252 小时前
UniApp开发应用多平台上架全流程:H5小程序iOS和Android
后端·ios
悟空码字2 小时前
告别“屎山代码”:AI 代码整洁器让老项目重获新生
后端·aigc·ai编程
小码哥_常2 小时前
大厂不宠@Transactional,背后藏着啥秘密?
后端
奋斗小强2 小时前
内存危机突围战:从原理辨析到线上实战,彻底搞懂 OOM 与内存泄漏
后端
小码哥_常3 小时前
Spring Boot接口防抖秘籍:告别“手抖”,守护数据一致性
后端
心之语歌3 小时前
基于注解+拦截器的API动态路由实现方案
java·后端
None3213 小时前
【NestJs】基于Redlock装饰器分布式锁设计与实现
后端·node.js
初次攀爬者3 小时前
Kafka + KRaft模式架构基础介绍
后端·kafka
洛森唛3 小时前
Elasticsearch DSL 查询语法大全:从入门到精通
后端·elasticsearch