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 的不同》
1373 0
|
20天前
|
SQL 关系型数据库 Nacos
【2026最新 架构环境安装篇四】Docker安装Nacos3.x详细教程
本文介绍了如何通过Docker快速部署Nacos 3.1.0并连接MySQL数据库。内容包括拉取镜像、导入SQL脚本、生成密钥及配置认证信息,并通过环境变量设置时区、数据库连接参数等,最终启动Nacos服务,实现高效本地或生产环境搭建。
311 3
|
5月前
|
XML Java Nacos
Spring Boot 整合Nacos 版本兼容适配 史上最详细文档
本文介绍SpringBoot整合Nacos的完整流程,涵盖Nacos下载安装、配置中心与服务发现集成、版本兼容性问题及实战配置。重点解决SpringBoot 3.3.0与Nacos版本适配难题,推荐使用Spring Cloud Alibaba方案,并提供项目开源地址供参考学习。
|
7月前
|
监控 安全 Java
SpringBoot应用-Actuator监控
Spring Boot Actuator 是 Spring Boot 提供的一个独立模块,旨在通过简单的方式提供应用程序的监控和管理功能。Actuator 内置了多种端点(Endpoints),可以用于查看应用的健康状况、配置属性、日志级别等。
1050 1
|
监控 Java Nacos
使用Spring Boot集成Nacos
通过上述步骤,Spring Boot应用可以成功集成Nacos,利用Nacos的服务发现和配置管理功能来提升微服务架构的灵活性和可维护性。通过这种集成,开发者可以更高效地管理和部署微服务。
4236 17
|
人工智能 自然语言处理 Java
Spring Cloud Alibaba AI 入门与实践
本文将介绍 Spring Cloud Alibaba AI 的基本概念、主要特性和功能,并演示如何完成一个在线聊天和在线画图的 AI 应用。
3699 8
|
监控 数据可视化 项目管理
WBS元素是什么?在项目管理中的作用与类型定义
工作分解结构(WBS)是项目管理中的重要工具,用于将复杂项目分解为更小、更易管理的任务或工作包。本文介绍了WBS的概念、特点、核心目标及其在项目管理中的作用,包括项目范围定义、任务分配、进度管理、预算控制和风险管理等方面。同时,文章还探讨了几种常见的WBS类型,如交付物导向型、阶段导向型、功能导向型和混合型WBS,并提供了创建有效WBS的步骤建议。最后,推荐了几款实用的项目管理工具,帮助团队更高效地管理和执行项目。
1606 7
|
负载均衡 监控 Java
SpringCloud常见面试题(一):SpringCloud 5大组件,服务注册和发现,nacos与eureka区别,服务雪崩、服务熔断、服务降级,微服务监控
SpringCloud常见面试题(一):SpringCloud 5大组件,服务注册和发现,nacos与eureka区别,服务雪崩、服务熔断、服务降级,微服务监控
28326 8
SpringCloud常见面试题(一):SpringCloud 5大组件,服务注册和发现,nacos与eureka区别,服务雪崩、服务熔断、服务降级,微服务监控