application.yaml 与 bootstrap.yaml

你对这两个文件有没有清晰认识?

application.yaml

  • 用途:主要用于应用程序的主要配置,包括数据库连接信息、端口号、日志级别、自定义属性等应用级别的设置。这是Spring Boot应用中最常见的配置文件,几乎所有自定义配置都会放在这里。
  • 加载时机application.yaml 在Spring应用上下文初始化之后被加载,这意味着大部分Bean的创建和自动配置都会考虑到这里的配置信息。
  • 覆盖:可以通过命令行参数、环境变量、Java系统属性等方式覆盖application.yaml中的配置。

bootstrap.yaml

  • 用途:主要用于应用程序的引导阶段配置,特别是与Spring Cloud相关的配置,如配置中心(Config Server)的地址。它的内容在应用程序的上下文初始化之前被加载,适合配置那些需要在Spring应用上下文启动之前就需要读取的属性,比如用来配置从何处加载主配置文件的地址。
  • 加载时机bootstrap.yaml 文件比application.yaml更早加载,它在应用程序的引导阶段就被处理,用于应用程序上下文初始化之前的配置,比如配置中心的配置。
  • 用途示例:当使用Spring Cloud Config Server来集中管理配置时,你需要在bootstrap.yaml中配置Config Server的地址,这样Spring Cloud会先从Config Server获取配置信息,再初始化Spring Boot应用。

这两大段在讲什么 不能简单讲一下吗?

知识储备

Bean:实现控制反转的一个java对象 加入到ioc容器当中

Spring上下文:Bean管理 资源访问 消息传递 生命周期管理  我就简单讲一下第一个【第一个最好讲】 Bean管理 : ApplicationContext 读取配置元数据(xml文件 java配置 注解 )根据这些数据创建Bean 实现控制反转

Spring上下文启动:加载配置  -》 bean读取 -》 bean的实例化 -》 bean的初始化 -》 启动后监听

容器初始化阶段(加载配置阶段)    springboot 会读取 application.yaml 文件 

bootstrap.yaml 文件在加载配置阶段前 就已经读取了 

bootstrap.yaml 更早加载,主要用于引导配置,影响整个应用的初始化;而 application.yaml 加载较晚,负责应用的主体配置,灵活性和可覆盖性更高。

说的什么乱起八糟!!!!!  我们来举例

bootstrap配置文件在Spring Boot应用的启动过程中比application配置文件具有更高的优先级。这意味着在应用初始化的最早阶段,Spring会先读取bootstrap文件中的配置。由于Nacos作为配置中心,负责提供应用运行时所需的配置信息,将其地址放在bootstrap中可以确保应用在加载其他任何配置或初始化Bean之前就能建立起与Nacos的连接,从而能够及时获取到所有必需的配置。

server:
  port: 3000 # 前端默认访问端口号为3000
  servlet:
    context-path: / # 前端默认访问的根路径
spring:
  application:
    name: gateway-service  # 程序名就是服务名
  cloud:
    nacos:      
        server-addr: 174.148.4.170:8848 #注册中心

 当然还有其他原因:

  1. 功能隔离: bootstrap配置主要用于应用程序的引导阶段,它配置的内容是用来引导Spring Boot应用上下文的创建,比如配置中心的地址、安全证书、加密解密的密钥等基础设施级别的设置。而application配置则是关于应用本身的业务逻辑和特性配置。将Nacos地址这样的基础设施配置与业务逻辑配置分离开来,有助于清晰地组织配置,同时也便于管理和维护。

  2. 安全性与稳定性: 将与配置中心通信的敏感信息和基础配置放在bootstrap中,可以减少这些关键信息被不当覆盖的风险,因为bootstrap的配置不容易被外部环境变量或其他配置源所覆盖。这对于生产环境尤其重要,保证了系统的稳定性和安全性。

  3. 避免循环依赖: 如果Nacos配置包含了应用运行所必需的参数(比如数据库连接字符串),而这些参数又存储在Nacos中,那么必须在应用启动时就正确设置Nacos的地址以获取这些参数,避免因配置加载顺序导致的潜在循环依赖问题

        在来看一下3: 想象一下,你的Spring Boot应用需要从Nacos获取数据库连接字符串等关键配置来初始化数据库访问组件(如DataSource)。然而,这些数据库连接信息实际上是存储在Nacos中的。这就形成了一个逻辑上的依赖链:应用启动 -> 连接Nacos -> 获取数据库配置 -> 初始化数据库连接。如果Nacos的地址或者连接Nacos所需的其他关键参数(如认证信息)也打算通过Nacos来管理,那么就会出现问题,因为这时应用在没有Nacos配置的情况下无法知道如何连接到Nacos以获取这些配置信息,形成了一种“鸡生蛋,蛋生鸡”的困境,即循环依赖。

看到这你应该清楚了 哪些应该写在bootstrap.yaml 哪些应该写在application.yaml 里面

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值