一文带你深入了解SpringBoot配置文件的优先级

 更新时间:2026年04月07日 09:02:14   作者:Full Stack Developme  
这篇文章主要为大家详细介绍了SpringBoot中配置文件的优先级以及实际应用建议,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下

一、基础优先级顺序

1. 文件位置优先级(从高到低)

1. 当前目录的 /config 子目录
   └── ./config/
2. 当前目录
   └── ./
3. classpath 下的 /config 包
   └── classpath:/config/
4. classpath 根路径
   └── classpath:/

2. 文件类型优先级

在同一目录下,如果有多个配置文件,优先级顺序为:

application.properties > application.yml

示例:如果 application.properties 和 application.yml 在同一个目录,application.properties 中的配置会覆盖 application.yml 中相同的配置。

二、多环境配置优先级

1. 多环境文件命名规则

application-{profile}.properties
application-{profile}.yml

2. 完整优先级顺序(从高到低)

1. 命令行参数
   └── java -jar app.jar --server.port=8081
2. 环境变量(操作系统级)
   └── export SERVER_PORT=8081
3. 特定 Profile 的配置文件(按位置优先级)
   └── application-dev.properties(或 yml)
4. 默认配置文件
   └── application.properties(或 yml)
5. Spring Boot 内置默认配置

3. 多环境配置示例

假设有 dev、prod、test 三个环境:

# application.properties(默认配置)
server.port=8080
app.name=MyApp
# application-dev.properties
server.port=8081
app.debug=true
# application-prod.properties
server.port=80
app.debug=false

读取规则

使用 spring.profiles.active=dev 时

  • 先读取 application.properties
  • 再读取 application-dev.properties,覆盖相同属性
  • 最终 server.port=8081

三、重复覆盖顺序详解

1. 不同位置配置文件的覆盖

假设存在以下位置的配置文件:

# 位置1: classpath:/application.properties
server.port=8080

# 位置2: classpath:/config/application.properties
server.port=8081

# 位置3: ./application.properties
server.port=8082

# 位置4: ./config/application.properties
server.port=8083

最终生效顺序:位置4 > 位置3 > 位置2 > 位置1

最终端口:8083

2. 不同格式配置文件的覆盖

# application.yml
server:
  port: 8080
  servlet:
    context-path: /api
properties
# application.properties
server.port=8081

结果

  • server.port=8081(properties 覆盖 yml)
  • server.servlet.context-path=/api(保持不变)

3. 多环境 + 多位置的复杂覆盖

# classpath:/application.properties
server.port=8080

# classpath:/application-dev.properties
server.port=8081

# classpath:/config/application.properties
server.port=8082

# classpath:/config/application-dev.properties
server.port=8083

使用 --spring.profiles.active=dev 时:

加载顺序:

  • classpath:/application.properties (8080)
  • classpath:/config/application.properties (8082) - 覆盖
  • classpath:/application-dev.properties (8081) - 覆盖
  • classpath:/config/application-dev.properties (8083) - 覆盖

最终端口:8083

四、配置加载顺序完整清单

Spring Boot 配置加载顺序(从高到低):

1. 命令行参数

2. Java 系统属性 (System.getProperties())

3. 操作系统环境变量

4. JNDI 属性 (java:comp/env)

5. RandomValuePropertySource (random.* 属性)

6. 特定 Profile 的配置文件(jar 包外)

7. 特定 Profile 的配置文件(jar 包内)

8. 默认配置文件(jar 包外)

9. 默认配置文件(jar 包内)

10. @PropertySource 注解配置

11. SpringApplication 默认属性

五、实际应用建议

1. 配置文件组织示例

项目结构:

├── src/main/resources/
│   ├── application.yml              # 通用配置
│   ├── application-dev.yml          # 开发环境
│   ├── application-test.yml         # 测试环境
│   └── application-prod.yml         # 生产环境
└── config/                          # 外部配置目录(生产环境)
    └── application-prod.yml          # 覆盖内部配置

2. 优先级最佳实践

# 1. 使用 application.yml 存放默认配置
spring:
  profiles:
    active: dev
  application:
    name: my-service
# 2. 环境特定配置放在 application-{profile}.yml
# application-dev.yml
server:
  port: 8080
  servlet:
    context-path: /dev
# 3. 敏感信息通过环境变量或命令行覆盖
# java -jar app.jar --db.password=${DB_PASSWORD}

3. 验证配置优先级的代码示例

@Component
public class ConfigPrinter implements ApplicationRunner {
    @Value("${server.port}")
    private String port;
    @Value("${app.name:default}")
    private String appName;
    @Autowired
    private Environment environment;
    @Override
    public void run(ApplicationArguments args) {
        System.out.println("Server Port: " + port);
        System.out.println("App Name: " + appName);
        // 查看所有激活的配置文件
        Arrays.stream(environment.getActiveProfiles())
            .forEach(profile -> System.out.println("Active Profile: " + profile));
    }
}

六、特殊情况处理

1. 使用 spring.config.location 强制指定

java -jar app.jar --spring.config.location=/opt/config/application.yml

此时只加载指定位置的配置文件,其他位置不加载。

2. 使用 spring.config.additional-location 补充

java -jar app.jar --spring.config.additional-location=/opt/config/

额外添加配置位置,仍然会加载默认位置的配置。

3. 配置文件的合并规则

  • 简单类型:后面的覆盖前面的
  • 集合/Map类型:完全覆盖,不是合并
  • 对象类型:属性级别的覆盖

示例

# application.yml
app:
  config:
    key1: value1
    key2: value2
# application-dev.yml
app:
  config:
    key1: new-value1

结果:只有 key1 被覆盖,key2 仍然保留。

理解这些优先级规则对于管理复杂的 Spring Boot 应用配置非常重要,可以避免配置冲突和意外的行为。

到此这篇关于一文带你深入了解SpringBoot配置文件的优先级的文章就介绍到这了,更多相关SpringBoot配置文件优先级内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • JavaWeb项目部署到服务器详细步骤详解

    JavaWeb项目部署到服务器详细步骤详解

    这篇文章主要介绍了JavaWeb项目如何部署到服务器,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-04-04
  • Spring Data JPA 设置字段默认值方式

    Spring Data JPA 设置字段默认值方式

    这篇文章主要介绍了Spring Data JPA设置字段默认值方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-11-11
  • QueryWrapper中查询的坑及解决

    QueryWrapper中查询的坑及解决

    这篇文章主要介绍了QueryWrapper中查询的坑及解决方案,具有很好的参考价值,希望对大家有所帮助。
    2022-01-01
  • Caffeine中本地缓存的最佳实践与性能优化指南

    Caffeine中本地缓存的最佳实践与性能优化指南

    作为 Java 生态中性能优异的本地缓存实现,Caffeine 提供了更高的吞吐量和更低的延迟,本文将深入剖析 Caffeine 的核心原理、源码实现和实际应用,希望对大家有所帮助
    2025-09-09
  • Java编程实现统计一个字符串中各个字符出现次数的方法

    Java编程实现统计一个字符串中各个字符出现次数的方法

    这篇文章主要介绍了Java编程实现统计一个字符串中各个字符出现次数的方法,涉及java针对字符串的遍历、判断、运算等相关操作技巧,需要的朋友可以参考下
    2017-12-12
  • Kotlin 基础教程之类、对象、接口

    Kotlin 基础教程之类、对象、接口

    这篇文章主要介绍了Kotlin 基础教程之类、对象、接口的相关资料,需要的朋友可以参考下
    2017-06-06
  • Java的JSON转换类库GSON的基础使用教程

    Java的JSON转换类库GSON的基础使用教程

    GSON是谷歌开源的一款Java对象与JSON对象互相转换的类库,Java的JSON转换类库GSON的基础使用教程,需要的朋友可以参考下
    2016-06-06
  • struts2数据处理_动力节点Java学院整理

    struts2数据处理_动力节点Java学院整理

    Struts2框架框架使用OGNL语言和值栈技术实现数据的流转处理。下面通过本文给大家分享struts2数据处理的相关知识,感兴趣的朋友参考下吧
    2017-09-09
  • java贪吃蛇游戏编写代码

    java贪吃蛇游戏编写代码

    这篇文章主要为大家详细介绍了java贪吃蛇游戏的编写代码,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-06-06
  • Maven项目打包为jar的四种方式

    Maven项目打包为jar的四种方式

    本文主要介绍了Maven项目打包为jar的四种方式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2024-10-10

最新评论