当前位置: 首页 > 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.lryc.cn/news/578643.html

相关文章:

  • SAFNet:一种基于CNN的轻量化故障诊断模型
  • 重构企业智能服务:大模型部署背后的战略与落地实践
  • WPF学习笔记(17)样式Style
  • 22页精品PPT | 数据治理平台与数据运营体系建设方案数据治理解决方案
  • 设置linux静态IP
  • 图神经网络(篇二)-基础知识
  • 板凳-------Mysql cookbook学习 (十一--------1)
  • Conda 虚拟环境克隆与 PyCharm 配置教程
  • 【算法 day13】LeetCode 110.平衡二叉树 | 257. 二叉树的所有路径| 404.左叶子之和 |222.完全二叉树的节点个数
  • Python实例题:基于 Python 的简单爬虫与数据可视化
  • 【仿muduo库实现并发服务器】eventloop模块
  • nanoGPT复现——bench.py和sample.py
  • 【MobaXterm、Vim】使用合集1
  • 【科研绘图系列】基于R语言的复杂热图绘制教程:环境因素与染色体效应的可视化
  • 用lines_gauss的width属性提取缺陷
  • Prompt生成指南
  • Unity-ComputeShader
  • UE5.6 官方文档笔记 [1]——虚幻编辑器界面
  • C#.Net筑基-优雅LINQ的查询艺术
  • 6.2 实现文档加载和切分和简易向量数据库的功能
  • 图像处理专业书籍以及网络资源总结
  • beego打包发布到Centos系统及国产麒麟系统完整教程
  • 前端第二节(Vue)
  • 微信小程序实现table表格
  • 微信小程序21~30
  • CppCon 2018 学习:EFFECTIVE REPLACEMENT OF DYNAMIC POLYMORPHISM WITH std::variant
  • Linux->进程控制(精讲)
  • 《P5522 [yLOI2019] 棠梨煎雪》
  • 如何分析大语言模型(LLM)的内部表征来评估文本的“诚实性”
  • 在 Docker 容器中使用内网穿透