Spring Boot 配置文件 bootstrap vs application 到底有什么區別?


用過 Spring Boot 的都知道在 Spring Boot 中有以下兩種配置文件

  • bootstrap (.yml 或者 .properties)
  • application (.yml 或者 .properties)

為什么會有這兩種配置文件呢?大家都清楚它們的區別和具體使用場景嗎?

bootstrap/ application 的區別

特意去翻了下 Spring Boot 的官方文檔,沒有找到關於這兩種文件的具體定義,然后再翻了下 Spring Cloud 的官方文檔找到了它們的區別。

https://cloud.spring.io/spring-cloud-static/Greenwich.SR1/single/spring-cloud.html#_the_bootstrap_application_context

認真閱讀了下文檔,原文大概意思是這樣。

Spring Cloud 構建於 Spring Boot 之上,在 Spring Boot 中有兩種上下文,一種是 bootstrap, 另外一種是 application, bootstrap 是應用程序的父上下文,也就是說 bootstrap 加載優先於 applicaton。bootstrap 主要用於從額外的資源來加載配置信息,還可以在本地外部配置文件中解密屬性。這兩個上下文共用一個環境,它是任何Spring應用程序的外部屬性的來源。bootstrap 里面的屬性會優先加載,它們默認也不能被本地相同配置覆蓋。

因此,對比 application 配置文件,bootstrap 配置文件具有以下幾個特性。

  • boostrap 由父 ApplicationContext 加載,比 applicaton 優先加載
  • boostrap 里面的屬性不能被覆蓋

bootstrap/ application 的應用場景

application 配置文件這個容易理解,主要用於 Spring Boot 項目的自動化配置。

bootstrap 配置文件有以下幾個應用場景。

  • 使用 Spring Cloud Config 配置中心時,這時需要在 bootstrap 配置文件中添加連接到配置中心的配置屬性來加載外部配置中心的配置信息;
  • 一些固定的不能被覆蓋的屬性
  • 一些加密/解密的場景;

以下這個截圖是一個國外網友問了一個 Spring Cloud 工程師得到的回答。

做過 Spring Cloud 微服務的朋友應該對 bootstrap 的應用十分清楚,我們的微信公眾號Java技術棧也有 Spring Cloud 的實戰教程,在 Spring 專題中都能看到。

好了,今天的分享就到這里,關注Java技術棧微信公眾號,在后台回復:boot,獲取棧長整理的更多的 Spring Boot 教程,都是實戰干貨,以下僅為部分預覽。

  • Spring Boot 讀取配置的幾種方式
  • Spring Boot 如何做參數校驗?
  • Spring Boot 最核心的 25 個注解!
  • Spring Boot 2.x 啟動全過程源碼分析
  • Spring Boot 2.x 新特性總結及遷移指南
  • ……

本文原創首發於微信公眾號:Java技術棧(id:javastack),轉載請原樣保留本信息。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM