SpringBoot application.yml和bootstrap.yml的區(qū)別
SpringBoot默認(rèn)支持properties和YAML兩種格式的配置文件。前者格式簡(jiǎn)單,但是只支持鍵值對(duì)。如果需要表達(dá)列表,最好使用YAML格式。SpringBoot支持自動(dòng)加載約定名稱(chēng)的配置文件,例如application.yml。如果是自定義名稱(chēng)的配置文件,就要另找方法了??上У氖?,不像前者有@PropertySource這樣方便的加載方式,后者的加載必須借助編碼邏輯來(lái)實(shí)現(xiàn)。
一、bootstrap.yml(bootstrap.properties)與application.yml(application.properties)執(zhí)行順序
bootstrap.yml(bootstrap.properties)用來(lái)在程序引導(dǎo)時(shí)執(zhí)行,應(yīng)用于更加早期配置信息讀取,如可以使用來(lái)配置application.yml中使用到參數(shù)等
application.yml(application.properties) 應(yīng)用程序特有配置信息,可以用來(lái)配置后續(xù)各個(gè)模塊中需使用的公共參數(shù)等。
bootstrap.yml 先于 application.yml 加載
二、典型的應(yīng)用場(chǎng)景如下:
- 當(dāng)使用 Spring Cloud Config Server 的時(shí)候,你應(yīng)該在 bootstrap.yml 里面指定 spring.application.name 和 spring.cloud.config.server.git.uri
- 和一些加密/解密的信息
技術(shù)上,bootstrap.yml 是被一個(gè)父級(jí)的 Spring ApplicationContext 加載的。這個(gè)父級(jí)的 Spring ApplicationContext是先加載的,在加載application.yml 的 ApplicationContext之前。
為何需要把 config server 的信息放在 bootstrap.yml 里?
當(dāng)使用 Spring Cloud 的時(shí)候,配置信息一般是從 config server 加載的,為了取得配置信息(比如密碼等),你需要一些提早的引導(dǎo)配置。因此,把 config server 信息放在 bootstrap.yml,用來(lái)加載在這個(gè)時(shí)期真正需要的配置信息。
三、高級(jí)使用場(chǎng)景
啟動(dòng)上下文
Spring Cloud會(huì)創(chuàng)建一個(gè)Bootstrap Context,作為Spring應(yīng)用的Application Context的父上下文。初始化的時(shí)候,Bootstrap Context負(fù)責(zé)從外部源加載配置屬性并解析配置。這兩個(gè)上下文共享一個(gè)從外部獲取的Environment。Bootstrap屬性有高優(yōu)先級(jí),默認(rèn)情況下,它們不會(huì)被本地配置覆蓋。 Bootstrap context和Application Context有著不同的約定,所以新增了一個(gè)bootstrap.yml文件,而不是使用application.yml (或者application.properties)。保證Bootstrap Context和Application Context配置的分離。下面是一個(gè)例子:
bootstrap.yml
spring: application: name: foo cloud: config: uri: ${SPRING_CONFIG_URI:http://localhost:8888}
推薦在bootstrap.yml or application.yml里面配置spring.application.name. 你可以通過(guò)設(shè)置spring.cloud.bootstrap.enabled=false來(lái)禁用bootstrap。
應(yīng)用上下文層次結(jié)構(gòu)
如果你通過(guò)SpringApplication或者SpringApplicationBuilder創(chuàng)建一個(gè)Application Context,那么會(huì)為spring應(yīng)用的Application Context創(chuàng)建父上下文Bootstrap Context。在Spring里有個(gè)特性,子上下文會(huì)繼承父類(lèi)的property sources and profiles ,所以main application context 相對(duì)于沒(méi)有使用Spring Cloud Config,會(huì)新增額外的property sources。額外的property sources有:
- “bootstrap” : 如果在Bootstrap Context掃描到PropertySourceLocator并且有屬性,則會(huì)添加到CompositePropertySource。Spirng Cloud Config就是通過(guò)這種方式來(lái)添加的屬性的,詳細(xì)看源碼ConfigServicePropertySourceLocator`。下面也也有一個(gè)例子自定義的例子。
- “applicationConfig: [classpath:bootstrap.yml]” ,(如果有spring.profiles.active=production則例如 applicationConfig: [classpath:/bootstrap.yml]#production): 如果你使用bootstrap.yml來(lái)配置Bootstrap Context,他比application.yml優(yōu)先級(jí)要低。它將添加到子上下文,作為Spring Boot應(yīng)用程序的一部分。下文有介紹。
由于優(yōu)先級(jí)規(guī)則,Bootstrap Context不包含從bootstrap.yml來(lái)的數(shù)據(jù),但是可以用它作為默認(rèn)設(shè)置。
你可以很容易的擴(kuò)展任何你建立的上下文層次,可以使用它提供的接口,或者使用SpringApplicationBuilder包含的方法(parent(),child(),sibling())。Bootstrap Context將是最高級(jí)別的父類(lèi)。擴(kuò)展的每一個(gè)Context都有有自己的bootstrap property source(有可能是空的)。擴(kuò)展的每一個(gè)Context都有不同spring.application.name。同一層層次的父子上下文原則上也有一有不同的名稱(chēng),因此,也會(huì)有不同的Config Server配置。子上下文的屬性在相同名字的情況下將覆蓋父上下文的屬性。
注意SpringApplicationBuilder允許共享Environment到所有層次,但是不是默認(rèn)的。因此,同級(jí)的兄弟上下文不在和父類(lèi)共享一些東西的時(shí)候不一定有相同的profiles或者property sources。
修改Bootstrap屬性配置
源碼位置BootstrapApplicationListener。
? ?String configName = environment.resolvePlaceholders("${spring.cloud.bootstrap.name:bootstrap}"); ? ? String configLocation = environment.resolvePlaceholders("${spring.cloud.bootstrap.location:}"); ? ? Map<String, Object> bootstrapMap = new HashMap<>();bootstrapMap.put("spring.config.name",configName); ? ? if(StringUtils.hasText(configLocation)){ ? ? ? ? bootstrapMap.put("spring.config.location", configLocation); ? ? }
bootstrap.yml是由spring.cloud.bootstrap.name(默認(rèn):”bootstrap”)或者spring.cloud.bootstrap.location(默認(rèn)空)。這些屬性行為與spring.config.*類(lèi)似,通過(guò)它的Environment來(lái)配置引導(dǎo)ApplicationContext。如果有一個(gè)激活的profile(來(lái)源于spring.profiles.active或者Environment的Api構(gòu)建),例如bootstrap-development.properties 就是配置了profile為development的配置文件.
覆蓋遠(yuǎn)程屬性
property sources被bootstrap context 添加到應(yīng)用通常通過(guò)遠(yuǎn)程的方式,比如”Config Server”。默認(rèn)情況下,本地的配置文件不能覆蓋遠(yuǎn)程配置,但是可以通過(guò)啟動(dòng)命令行參數(shù)來(lái)覆蓋遠(yuǎn)程配置。如果需要本地文件覆蓋遠(yuǎn)程文件,需要在遠(yuǎn)程配置文件里設(shè)置授權(quán)
spring.cloud.config.allowOverride=true(這個(gè)配置不能在本地被設(shè)置)。一旦設(shè)置了這個(gè)權(quán)限,你可以配置更加細(xì)粒度的配置來(lái)配置覆蓋的方式,
比如:
- spring.cloud.config.overrideNone=true 覆蓋任何本地屬性
- spring.cloud.config.overrideSystemProperties=false 僅僅系統(tǒng)屬性和環(huán)境變量
源文件見(jiàn)PropertySourceBootstrapProperties
自定義啟動(dòng)配置
bootstrap context是依賴(lài)/META-INF/spring.factories文件里面的org.springframework.cloud.bootstrap.BootstrapConfiguration條目下面,通過(guò)逗號(hào)分隔的Spring @Configuration類(lèi)來(lái)建立的配置。任何main application context需要的自動(dòng)注入的Bean可以在這里通過(guò)這種方式來(lái)獲取。這也是ApplicationContextInitializer建立@Bean的方式。可以通過(guò)@Order來(lái)更改初始化序列,默認(rèn)是”last”。
# spring-cloud-context-1.1.1.RELEASE.jar # spring.factories # AutoConfiguration org.springframework.boot.autoconfigure.EnableAutoConfiguration=\ org.springframework.cloud.autoconfigure.ConfigurationPropertiesRebinderAutoConfiguration,\ org.springframework.cloud.autoconfigure.RefreshAutoConfiguration,\ org.springframework.cloud.autoconfigure.RefreshEndpointAutoConfiguration,\ org.springframework.cloud.autoconfigure.LifecycleMvcEndpointAutoConfiguration # Application Listeners org.springframework.context.ApplicationListener=\ org.springframework.cloud.bootstrap.BootstrapApplicationListener,\ org.springframework.cloud.context.restart.RestartListener # Bootstrap components org.springframework.cloud.bootstrap.BootstrapConfiguration=\ org.springframework.cloud.bootstrap.config.PropertySourceBootstrapConfiguration,\ org.springframework.cloud.bootstrap.encrypt.EncryptionBootstrapConfiguration,\ org.springframework.cloud.autoconfigure.ConfigurationPropertiesRebinderAutoConfiguration,\ org.springframework.boot.autoconfigure.PropertyPlaceholderAutoConfiguration
警告
小心,你添加的自定義BootstrapConfiguration類(lèi)沒(méi)有錯(cuò)誤的@ComponentScanned到你的主應(yīng)用上下文,他們可能是不需要的。使用一個(gè)另外的包不被@ComponentScan或者@SpringBootApplication注解覆蓋到。
bootstrap context通過(guò)spring.factories配置的類(lèi)初始化的所有的Bean都會(huì)在SpingApplicatin啟動(dòng)前加入到它的上下文里去。
自定義引導(dǎo)配置來(lái)源:Bootstrap Property Sources
默認(rèn)的property source添加額外的配置是通過(guò)配置服務(wù)(Config Server),你也可以自定義添加property source通過(guò)實(shí)現(xiàn)PropertySourceLocator接口來(lái)添加。你可以使用它加配置屬性從不同的服務(wù)、數(shù)據(jù)庫(kù)、或者其他。
下面是一個(gè)自定義的例子:
@Configuration public class CustomPropertySourceLocator implements PropertySourceLocator { ? ? @Override ? ? public PropertySource<?> locate(Environment environment) { ? ? ? ? return new MapPropertySource("customProperty", ? ? ? ? ? ? ? ? Collections.<String, Object>singletonMap("property.from.sample.custom.source", "worked as intended")); ? ? } }
Environment被ApplicationContext建立,并傳入property sources(可能不同個(gè)profile有不同的屬性),所以,你可以從Environment尋找找一些特別的屬性。比如spring.application.name,它是默認(rèn)的Config Server property source。
如果你建立了一個(gè)jar包,里面添加了一個(gè)META-INF/spring.factories文件:
org.springframework.cloud.bootstrap.BootstrapConfiguration=sample.custom.CustomPropertySourceLocator
那么,”customProperty“的PropertySource將會(huì)被包含到應(yīng)用。
到此這篇關(guān)于SpringBoot application.yml和bootstrap.yml的區(qū)別的文章就介紹到這了,更多相關(guān)SpringBoot application.yml bootstrap.yml內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- SpringBoot配置文件bootstrap和application區(qū)別及說(shuō)明
- springboot項(xiàng)目中的bootstrap.yml配置不生效的原因及解決(沒(méi)有自動(dòng)提示)
- 解決Springboot項(xiàng)目bootstrap.yml不生效問(wèn)題
- springboot項(xiàng)目集成swagger-bootstrap-ui全過(guò)程
- SpringBoot項(xiàng)目集成Swagger和swagger-bootstrap-ui及常用注解解讀
- springboot讀取bootstrap配置及knife4j版本兼容性問(wèn)題及解決
相關(guān)文章
java堆棧類(lèi)使用實(shí)例(java中stack的使用方法)
java中stack的使用方法,堆棧是一種"后進(jìn)先出"(LIFO) 的數(shù)據(jù)結(jié)構(gòu), 只能在一端進(jìn)行插入(稱(chēng)為"壓棧") 或刪除 (稱(chēng)為"出棧")數(shù)據(jù)的操作,下面看示例吧2013-12-12詳解SpringBoot?統(tǒng)一后端返回格式的方法
今天我們來(lái)聊一聊在基于SpringBoot前后端分離開(kāi)發(fā)模式下,如何友好的返回統(tǒng)一的標(biāo)準(zhǔn)格式以及如何優(yōu)雅的處理全局異常,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2022-05-05Java的Hibernate框架中的組合映射學(xué)習(xí)教程
組合映射即是指主對(duì)象和子對(duì)象關(guān)聯(lián)且擁有相同的生命周期的映射關(guān)系,這里我們將舉一些數(shù)據(jù)操作的實(shí)例,來(lái)講解Java的Hibernate框架中的組合映射學(xué)習(xí)教程2016-07-07SpringCloud OpenFeign Post請(qǐng)求400錯(cuò)誤解決方案
這篇文章主要介紹了SpringCloud OpenFeign Post請(qǐng)求400錯(cuò)誤解決方案,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-09-09學(xué)習(xí)Java模擬實(shí)現(xiàn)百度文檔在線瀏覽
這片文章介紹了如何使用Java模擬實(shí)現(xiàn)百度文檔在線瀏覽,文章思路清晰,需要的朋友可以參考下2015-07-07SpringBoot基礎(chǔ)教程之集成郵件服務(wù)
這篇文章主要給大家介紹了關(guān)于SpringBoot基礎(chǔ)教程之集成郵件服務(wù)的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者使用SpringBoot具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07