当前位置: 首页 > news >正文

Spring Boot 2 多模块项目中配置文件的加载顺序

Spring Boot 2 多模块项目中配置文件的加载顺序

在 Spring Boot 2 多模块项目中,配置文件的加载遵循特定的顺序规则。了解这些规则对于正确管理多模块应用的配置至关重要。

一、默认配置文件加载顺序

Spring Boot 会按照以下顺序加载 application.propertiesapplication.yml 文件:

  1. 当前模块的 config 目录 (位于 classpath 根目录下)

    • classpath:/config/application.properties
    • classpath:/config/application.yml
  2. 当前模块的根目录

    • classpath:/application.properties
    • classpath:/application.yml
  3. 父模块的 config 目录 (如果存在依赖关系)

    • classpath:/../config/application.properties (相对路径)
    • classpath:/../config/application.yml
  4. 父模块的根目录

    • classpath:/../application.properties
    • classpath:/../application.yml

二、多模块项目中的特殊加载规则

1. 模块间配置继承

  • 子模块会自动继承父模块的配置
  • 子模块的配置会覆盖父模块的同名配置
  • 使用 spring.config.import 可以显式导入其他模块的配置

2. Profile 特定的配置

对于 application-{profile}.properties/yml 文件:

  • 加载顺序与主配置文件相同
  • Profile 配置会覆盖主配置

3. 外部化配置加载顺序

除了 classpath 内的配置,Spring Boot 还会按以下顺序加载外部配置:

  1. 当前目录的 /config 子目录
  2. 当前目录
  3. classpath 的 /config
  4. classpath 根目录

三、多模块配置管理最佳实践

1. 推荐的项目结构

parent-module/
├── common-module/          # 公共模块
│   └── src/main/resources/
│       ├── application.yml # 公共基础配置
│       └── application-{profile}.yml
├── service-module/         # 业务模块
│   └── src/main/resources/
│       ├── application.yml # 模块特有配置
│       └── application-{profile}.yml
└── web-module/            # Web模块└── src/main/resources/├── application.yml└── application-{profile}.yml

2. 配置覆盖示例

父模块 (common) application.yml:

server:port: 8080
spring:datasource:url: jdbc:mysql://localhost:3306/common_db

子模块 (web) application.yml:

server:port: 8081  # 覆盖父模块的端口配置
spring:datasource:url: jdbc:mysql://localhost:3306/web_db # 覆盖数据源配置

3. 显式导入配置

Spring Boot 2.4+ 支持使用 spring.config.import:

# service-module 的 application.yml
spring:config:import:- classpath:application-common.yml  # 导入公共配置- optional:classpath:application-override.yml # 可选导入

四、调试配置加载顺序

1. 查看生效的配置

启动应用时添加参数:

java -jar your-app.jar --debug

或在日志中设置:

logging:level:org.springframework.boot.context.config: TRACE

2. 查看 PropertySources

在应用中注入并输出:

@Autowired
private ConfigurableEnvironment env;@PostConstruct
public void printProperties() {env.getPropertySources().forEach(ps -> {System.out.println("PropertySource: " + ps.getName());});
}

五、常见问题解决方案

1. 配置不生效

  • 检查文件位置是否正确
  • 确认文件名拼写(注意 application 的全小写)
  • 检查模块依赖是否正确

2. Profile 配置未加载

  • 确保激活了正确的 profile:
    java -jar your-app.jar --spring.profiles.active=dev
    

3. 多模块配置冲突

  • 使用前缀区分不同模块的配置:
    # common 模块
    common:datasource:url: jdbc:mysql://localhost/common# web 模块
    web:datasource:url: jdbc:mysql://localhost/web
    

通过合理组织多模块项目的配置文件,可以确保配置的正确加载和覆盖,同时保持各模块配置的清晰性和可维护性。

http://www.dtcms.com/a/263798.html

相关文章:

  • 智能交通信号灯
  • Django打造智能Web机器人控制平台
  • HarmonyOS应用开发高级认证知识点梳理 (三)状态管理V2装饰器核心规则
  • android车载开发之HVAC
  • 笔记本电脑怎样投屏到客厅的大电视?怎样避免将电脑全部画面都投出去?
  • 【蓝牙】Linux Qt4查看已经配对的蓝牙信息
  • 05【C++ 入门基础】内联、auto、指针空值
  • 算法-每日一题(DAY12)最长和谐子序列
  • 为Mkdocs网站添加Google广告
  • CRMEB开源商城系统Windows+IIS环境安装配置详解
  • word中一行未满但是后面有空白行
  • 每日一练:找到初始输入字符串 I
  • AbMole| H₂DCFDA(M9096;活性氧(ROS)探针)
  • MySQL索引深度解析:B+树、B树、哈希索引怎么选?
  • 凸包进阶旋转卡壳(模板题目集)
  • Window 2000 Perfectional_配置和管理FTP
  • uniapp内置蓝牙打印
  • Qt小组件 - 1(手风琴)
  • 计算机网络:【socket】【UDP】【地址转换函数】【TCP】
  • 测试第六讲-测试模型分类
  • CloudBase AI ToolKit实战:从0到1开发一个智能医疗网站
  • 时空数据挖掘五大革新方向详解篇!
  • 电机控制——电机位置传感器零位标定
  • 安防监控视频汇聚平台EasyCVR v3.7.2版云端录像无法在web端播放的原因排查和解决方法
  • springboot3.2/3.4+rocketmq5.3.3测试程序的基本例子
  • SSVEP Next:现代化的 SSVEP 可视化 Web 快速实现
  • CAU数据挖掘实验 表分析数据插件
  • 【第二章:机器学习与神经网络概述】04.回归算法理论与实践 -(2)支持向量回归(SVR)
  • 软考中级【网络工程师】第6版教材 第1章 计算机网络概述
  • MATLAB构建capm和三因子模型