SpringBoot加载配置文件的优先级

在 SpringBoot 应用中,配置文件的加载顺序(优先级)决定了不同来源的配置属性如何覆盖彼此,但是,在实践中,也会经常遇到。下面文章将分析 SpringBoot 配置文件加载的优先级,从高到低排列。

文章目录

  • [1. 命令行参数](#1. 命令行参数)
  • [2. Java 系统属性](#2. Java 系统属性)
  • [3. 操作系统环境变量](#3. 操作系统环境变量)
  • [4. random 配置属性源(Random Configuration Property Sources):](#4. random 配置属性源(Random Configuration Property Sources):)
  • [5. application.{profile}.properties 或 application.{profile}.yml 文件](#5. application.{profile}.properties 或 application.{profile}.yml 文件)
  • [6. application.properties 或 application.yml 文件](#6. application.properties 或 application.yml 文件)
  • [7. @PropertySource 注解指定的属性文件](#7. @PropertySource 注解指定的属性文件)
  • [8. 默认属性](#8. 默认属性)
  • 总结

1. 命令行参数

  • 通过命令行(Command-line arguments)传递的参数具有最高优先级。

  • 如下示例,在启动应用时传递命令行参数--server.port=8081

java 复制代码
java -jar myapp.jar --server.port=8081

2. Java 系统属性

  • 在启动应用时通过 -D 选项设置的系统属性。

  • 如下示例,在启动应用时设置 -Dserver.port=8081 系统属性:

java 复制代码
java -Dserver.port=8081 -jar myapp.jar

3. 操作系统环境变量

  • 设置在操作系统级别的环境变量。例如,SERVER_PORT=8081

4. random 配置属性源(Random Configuration Property Sources):

  • 包括 random.* 属性,用于生成随机数或其他随机相关的配置。

5. application.{profile}.properties 或 application.{profile}.yml 文件

  • 基于当前激活的 Spring Profile 加载的配置文件。例如,如果激活了 dev 环境,则加载 application-dev.properties

6. application.properties 或 application.yml 文件

  • 默认的配置文件,通常位于 src/main/resources 目录下。

7. @PropertySource 注解指定的属性文件

  • 通过在配置类上使用 @PropertySource 注解加载的自定义属性文件。

8. 默认属性

  • 使用 SpringApplication.setDefaultProperties 设定的默认属性。

配置文件的搜索顺序

  • Spring Boot 在不同位置搜索 application.propertiesapplication.yml 文件,以下是搜索的顺序,从高到低优先级:
  1. 外部位置(当前目录、上级目录等):

    • file:./config/
    • file:./
    • file:../config/
    • file:../
  • 如果你在应用程序的当前目录或其上级目录中有配置文件,这些文件的优先级高于类路径下的配置文件。
  1. 类路径下的 /config 子目录:

    • classpath:/config/
  2. 类路径根目录:

    • classpath:/

配置优先级示例

假设存在以下配置来源:

  • application.properties 在类路径根目录中设置 server.port=8080
  • application-dev.properties 在类路径下的 config 目录中设置 server.port=8081
  • 外部 application.properties 文件设置 server.port=8082
  • 命令行参数传递 --server.port=8083

在激活 dev Profile 的情况下,最终 server.port 的值将是 8083。这是因为命令行参数的优先级最高,覆盖了其他所有配置来源。

激活 Profile

可以通过以下方式激活特定的 Spring Profile:

  • 命令行参数:
java 复制代码
java -jar myapp.jar --spring.profiles.active=dev
  • 环境变量:

    设置 SPRING_PROFILES_ACTIVE=dev

  • 配置文件:

    application.properties 中设置 spring.profiles.active=dev

属性覆盖规则

  • 同一属性名在多个来源中定义时,优先级高的来源会覆盖低的。例如:

    • application.properties 中定义 app.name=MyApp
    • 外部 application.properties 中定义 app.name=ExternalApp

若外部位置的配置文件优先级更高,则最终 app.nameExternalApp

总结

Spring Boot 的配置文件加载优先级有助于:

  • 正确组织和管理配置文件,确保不同环境下的配置正确应用。
  • 避免意外覆盖,通过明确的优先级控制哪些配置生效。
  • 优化配置管理流程,尤其是在复杂项目或多环境部署时。
相关推荐
CodeUp.15 分钟前
基于SpringBoot的OA办公系统的设计与实现
spring boot·后端·mybatis
小醉你真好19 分钟前
Spring Boot + ShardingSphere 分库分表实战
java·spring boot·后端·mysql
Vdeilae33 分钟前
IIS 让asp.net core 项目一直运行
java·服务器·asp.net
YY_TJJ1 小时前
8.4 Java Web(Maven P50-P57)
java·开发语言·maven
cc蒲公英1 小时前
uniapp x swiper/image组件mode=“aspectFit“ 图片有的闪现后黑屏
java·前端·uni-app
刘大辉在路上1 小时前
IntelliJ IDEA开发编辑器摸鱼看股票数据
java·编辑器·intellij-idea
Jacob02341 小时前
Node.js 性能瓶颈与 Rust + WebAssembly 实战探索
后端·rust·node.js
王中阳Go1 小时前
分库分表之后如何使用?面试可以参考这些话术
后端·面试
知其然亦知其所以然1 小时前
ChatGPT太贵?教你用Spring AI在本地白嫖聊天模型!
后端·spring·ai编程
我来整一篇2 小时前
[mysql] 深分页优化
java·数据库·mysql