SpringBoot配置文件加载顺序与优先级的详细步骤

 更新时间:2026年01月16日 09:49:27   作者:程序员码小跳  
在 Spring Boot 应用中,配置文件的加载顺序和优先级决定了最终生效的配置值,理解这一机制对于正确管理应用配置至关重要,所以本文给大家介绍了SpringBoot配置文件加载顺序与优先级的详细步骤,需要的朋友可以参考下

1. 概述

在 Spring Boot 应用中,配置文件的加载顺序和优先级决定了最终生效的配置值。理解这一机制对于正确管理应用配置至关重要,特别是在复杂的多模块项目中,配置文件的组织和优先级关系直接影响应用的行为。

2. 配置文件加载机制

比如我们定义了如下的 profile 配置:

profiles:
  active: ${PROFILES_ACTIVE:local}
  include: security,xxl-job,flyway,default,file,${NIMBUS_DB_TYPE:postgresql}

这个配置定义了主配置文件和需要额外加载的配置文件集合。Spring Boot 会按照特定的顺序加载这些配置文件,并根据优先级规则决定最终的配置值。

3. 配置文件优先级规则详解

Spring Boot 遵循以下优先级顺序,数字越小优先级越高,后加载的配置会覆盖先加载的同名配置:

3.1 最高优先级配置文件

application-{active_profile}.yaml

  - 优先级最高
  - 这是当前激活的 profile 对应的配置文件
  - 此文件中的配置会覆盖其他所有配置文件中的同名配置

3.2 通过 include 指令加载的配置文件

按 include 列表中的顺序依次加载,后加载的配置文件会覆盖先加载的同名配置

3.2.1 [application-security.yaml]- list中优先级最低

  • 首先加载安全相关的配置
  • 包含认证、授权等安全相关配置项
  • 在后续配置文件加载时可能被覆盖

3.2.2 [application-xxl-job.yaml]- 优先级中等偏低

  • 加载分布式任务调度框架 XXL-JOB 的相关配置
  • 可能覆盖安全配置中的某些属性

3.2.3 [application-flyway.yaml】 优先级中等

  • 加载数据库迁移工具 Flyway 的配置
  • 通常包含数据库迁移相关的属性

3.2.4 [application-default.yaml] - 优先级中等偏高

  • 加载默认配置
  • 通常包含通用的默认设置

3.2.5 [application-file.yaml]- 优先级较高

  • 加载文件服务相关的配置
  • 可能覆盖之前的通用配置

3.2.6 [application-postgresql.yaml] - 优先级最高(在 include 列表中)

  • 最后加载数据库配置
  • 由于是 include 列表中最后一个加载的文件,它的配置会覆盖 include 列表中其他文件的同名配置
  • 但仍然低于 [application-{active_profile}.yaml]

3.3 基础配置文件

  • [application.yaml] 最终的基础配置
  • 作为兜底配置,提供最基本的配置项
  • 优先级最低,容易被其他配置文件覆盖

4. 配置覆盖规则详解

4.1 属性覆盖原则

  • 在不同优先级的配置文件中,相同属性名的值会按照优先级规则进行覆盖
  • 高优先级配置文件中的属性值会覆盖低优先级配置文件中的同名属性值
  • 例如,如果 [application-security.yaml]中定义了 server.port=9001,而 [application-postgresql.yaml]中定义了 server.port=9002,则最终生效的端口将是 9002

4.2 Profile 特定配置优先级

  • [application-{profile}.properties] 优先级最高高
  • 这意味着特定环境的配置总是优先于通用配置

4.3 配置属性的合并行为

  • 对于复合类型的配置(如 lists, maps),Spring Boot 会根据属性来源进行合并或替换
  • 简单属性(String, int, boolean 等)直接被高优先级配置覆盖
  • 复杂属性可能涉及合并逻辑,需要注意配置设计

4.4 具体配置覆盖示例

假设有以下配置项分布在不同文件中:

[application-security.yaml]:

server:
  port: 9001
logging:
  level:
    com.nimbus: DEBUG

[application-postgresql.yaml]

server:
  port: 9002
spring:
  datasource:
    url: jdbc:postgresql://localhost:5432/mydb

[application-local.yaml]

server:
  port: 9003
logging:
  level:
    com.nimbus: INFO

最终生效的配置:

server:
  port: 9003  # 来自 application-local.yaml (最高优先级)
logging:
  level:
    com.nimbus: INFO  # 来自 application-local.yaml (最高优先级)
spring:
  datasource:
    url: jdbc:postgresql://localhost:5432/mydb  # 来自 application-postgresql.yaml

以上就是SpringBoot配置文件加载顺序与优先级的详细步骤的详细内容,更多关于SpringBoot文件加载顺序与优先级配置的资料请关注脚本之家其它相关文章!

相关文章

  • Java集成和使用dl4j实现通过扫描图片识别快递单信息

    Java集成和使用dl4j实现通过扫描图片识别快递单信息

    这篇文章主要为大家详细介绍了Java如何使用DL4J搭建一个简单的图像识别模型,并将其集成到Spring Boot后端中从而实现通过扫描图片识别快递单信息,需要的可以参考下
    2024-12-12
  • 利用SpringBoot实现RSA+AES混合加密

    利用SpringBoot实现RSA+AES混合加密

    用户注册时,密码明文传输被拦截?支付信息在传输过程中被窃取?或者敏感数据在接口调用时被中间人攻击?再或者App被反编译,接口参数被破解?今天我们就来聊聊如何用SpringBoot实现RSA+AES混合加密,让你的接口数据传输更安全,需要的朋友可以参考下
    2026-01-01
  • Spring Cloud Gateway 内存溢出的解决方案

    Spring Cloud Gateway 内存溢出的解决方案

    这篇文章主要介绍了Spring Cloud Gateway 内存溢出的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-07-07
  • 使用Runtime 调用Process.waitfor导致的阻塞问题

    使用Runtime 调用Process.waitfor导致的阻塞问题

    这篇文章主要介绍了使用Runtime 调用Process.waitfor导致的阻塞问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-12-12
  • Java并发 CompletableFuture异步编程的实现

    Java并发 CompletableFuture异步编程的实现

    这篇文章主要介绍了Java并发 CompletableFuture异步编程的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-01-01
  • JAVA JNI函数的注册过程详细介绍

    JAVA JNI函数的注册过程详细介绍

    这篇文章主要介绍了JAVA JNI函数的注册过程详细介绍的相关资料,需要的朋友可以参考下
    2016-11-11
  • Springboot整合SpringSecurity实现登录认证和鉴权全过程

    Springboot整合SpringSecurity实现登录认证和鉴权全过程

    这篇文章主要介绍了Springboot整合SpringSecurity实现登录认证和鉴权全过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-12-12
  • Java实现对中文字符串的排序功能实例代码

    Java实现对中文字符串的排序功能实例代码

    这篇文章主要介绍了Java实现中文字符串的排序功能实例代码的相关资料,需要的朋友可以参考下
    2016-04-04
  • MySqlConnector的使用教程

    MySqlConnector的使用教程

    本文详细介绍了MySqlConnector的核心功能,包括数据变更捕获、KafkaConnect兼容性、配置管理、版本信息、连接器任务创建、配置验证、数据库连接建立和连接器配置创建等,感兴趣的可以了解一下
    2024-10-10
  • 解读Spring接口方法加@Transactional失效的原因

    解读Spring接口方法加@Transactional失效的原因

    这篇文章主要介绍了Spring接口方法加@Transactional失效的原因解读,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-03-03

最新评论