application.yml和bootstrap.yml这两个配置文件有什么区别?

简介: `bootstrap.yml` 与 `application.yml` 是 Spring Boot/Cloud 项目中的两类配置文件。前者用于应用启动前加载,主要配置远程配置中心(如 Nacos)、加密等关键信息,优先级高;后者是默认主配置,用于常规配置如端口、数据库等。自 Spring Boot 2.4+ 起,默认不再启用 `bootstrap` 机制,推荐使用 `spring.config.import` 在 `application.yml` 中统一导入配置,以简化流程、降低复杂度。纯 Spring Boot 应用不加载 `bootstrap.yml`。

application.ymlbootstrap.yml 是 Spring Boot / Spring Cloud 项目中常见的两种配置文件,它们的主要区别在于加载时机、用途和作用范围。

bootstrap.yml 是 Spring Cloud 的特性,不是 Spring Boot 本身的特性。application.yml 是 Spring Boot 的特性。所以,如果是纯 Spring Boot 应用,则不会加载bootstrap.yml


一、加载顺序不同

  • bootstrap.yml(或 bootstrap.properties):
  • 在 Spring 应用上下文启动之前加载。优先级 高于 application.yml
  • application.yml(或 application.properties):
  • 在 Spring 应用上下文创建过程中加载。
  • 是 Spring Boot 默认的主配置文件。

bootstrap 翻译过来就是 “引导程序”、“启动程序”,所以,以他命名的文件要最先开始做加载。


二、使用场景不同

bootstrap.yml 主要用于初始化 Spring Cloud 相关的配置(如配置中心、加密解密等)。常见的就是如果你的 Spring 应用需要接入配置中心,比如 nacos,那么 nacos 相关的配置就需要放在 bootstrap.yml 中。

bootstrap.yml 典型使用场景:

  • 使用 Spring Cloud Config Server 获取远程配置
  • 使用 Spring Cloud Vault 管理敏感信息
  • 使用 Nacos / Consul / Zookeeper 作为配置中心

application.yml 用来配置普通的应用配置信息,如数据库连接、端口、日志级别等,还有一些业务相关配置项等。


三、bootstrap.yml 默认不开启

需要注意的是,在较新版本的 Spring Boot 2.4+ 及其后续 Spring Cloud 版本中,它的默认支持被移除,并引入了spring.config.import机制来替代旧的 Bootstrap 上下文加载方式,推荐将配置转移到 application.yml,或者通过添加 spring-cloud-starter-bootstrap 依赖来恢复支持。

主要变化是配置中心(如 Nacos、Apollo)的加载方式从 bootstrap.yml 的特殊处理转变为通过 spring.config.import 属性导入,使得配置更加统一。

这么做的原因:

  • 简化启动流程:Bootstrap 上下文增加了复杂性和启动时间。
  • 推动更现代的配置方式:如 Nacos、Consul、Config Server 现在支持通过 application.yml 直接配置,无需 bootstrap。
  • 减少 “魔法” 行为:避免开发者困惑为啥某些配置在 bootstrap.yml 才生效。
目录
相关文章
|
安全 Java 数据库连接
《Spring Boot配置文件大揭秘:看懂 application.yaml 与 bootstrap.yaml 的不同》
《Spring Boot配置文件大揭秘:看懂 application.yaml 与 bootstrap.yaml 的不同》
1513 0
|
5月前
|
人工智能 自然语言处理 数据可视化
Java与AI的深度融合:JBoltAI赋能基础AI能力探索
本文介绍JBoltAI框架如何赋能Java开发者快速构建AI应用,涵盖数据管理、可视化、OCR识别、Text2SQL/JSON、流式对话及多模态交互等核心能力,并支持20+大模型无缝接入,推动Java迈向AIGS新时代。(239字)
411 3
|
10月前
|
XML Java Nacos
Spring Boot 整合Nacos 版本兼容适配 史上最详细文档
本文介绍SpringBoot整合Nacos的完整流程,涵盖Nacos下载安装、配置中心与服务发现集成、版本兼容性问题及实战配置。重点解决SpringBoot 3.3.0与Nacos版本适配难题,推荐使用Spring Cloud Alibaba方案,并提供项目开源地址供参考学习。
|
6月前
|
负载均衡 Java Spring
Feign 和 OpenFeign 有什么区别?
Feign是Netflix开发的声明式HTTP客户端,简化Web服务调用。OpenFeign是Spring Cloud对其的扩展,集成负载均衡、服务发现等组件,提供自动配置,更适用于Spring生态。
569 1
|
域名解析 Kubernetes Java
图文详述Nacos配置中心使用:应用间配置共享、扩展配置文件加载优先级、新老版本差异
图文详述Nacos配置中心使用:应用间配置共享、扩展配置文件加载优先级、新老版本差异
7446 1
图文详述Nacos配置中心使用:应用间配置共享、扩展配置文件加载优先级、新老版本差异
|
6月前
|
负载均衡 Dubbo Java
Dubbo 和 Feign的区别是什么?
Dubbo是高性能RPC框架,支持多种协议与服务治理,适用于Java微服务架构;Feign是声明式HTTP客户端,简化Spring Cloud服务调用。两者定位不同,Dubbo强在性能与治理,Feign重在易用与集成。
744 0
|
7月前
|
安全 Java jenkins
Spring Boot 多环境配置与 Profile 实战
Spring Boot通过Profile实现多环境配置,支持dev、test、prod等环境的独立配置。通过application-{profile}.yml分离配置,结合spring.profiles.active动态激活,实现一套代码适配多套环境,提升部署效率与安全性。
|
7月前
|
缓存 安全
String,StringBuilder 和 StringBuffer 的区别
String不可变,StringBuilder与StringBuffer可变;后者线程不安全,StringBuffer线程安全。大量拼接时优先选用后两者,多线程用StringBuffer,单线程用StringBuilder。String因final设计保证不可变,利于安全与缓存。
|
7月前
|
SQL 容灾 数据库
分布式事务Seata
Seata是阿里开源的分布式事务解决方案,提供XA、AT、TCC、SAGA四种模式,解决微服务架构下的跨库跨服务事务一致性问题。通过TC(事务协调者)、TM、RM三大角色实现全局事务管理,支持高可用部署与无缝集成Spring Cloud,助力系统实现最终一致或强一致性事务。
815 0
|
8月前
|
消息中间件 缓存 JSON
http 调用优化 的11大绝招 (图解+秒懂+史上最全)
http 调用优化 的11大绝招 (图解+秒懂+史上最全)

热门文章

最新文章