springBoot項(xiàng)目配置文件加載優(yōu)先級(jí)及同配置覆蓋問(wèn)題詳解
背景:
由于目前網(wǎng)上對(duì)于springboot配置文件的加載問(wèn)題,存在著各種不同的說(shuō)法。所以導(dǎo)致自己不敢確定到底何種結(jié)論才是真正正確的,故專門花費(fèi)了一些時(shí)間進(jìn)行親自驗(yàn)證。
驗(yàn)證:
在經(jīng)過(guò)自己對(duì)配置文件的加載問(wèn)題進(jìn)行驗(yàn)證后,發(fā)現(xiàn)所謂配置文件的優(yōu)先級(jí)并不一定是固定不變的,而是會(huì)受一些前提條件的影響。下面將對(duì)bootstrap.properties、bootstrap.yml、application.properties、application.yml這四種我們可能使用到的配置文件的加載優(yōu)先級(jí)問(wèn)題進(jìn)行詳細(xì)的說(shuō)明(此處以springCloud微服務(wù)項(xiàng)目為背景,不然單純的springBoot項(xiàng)目是不會(huì)加載bootstrap配置文件的,且以下說(shuō)明默認(rèn)配置文件都是在同一目錄)。
一.非活動(dòng)的profile
首先,在默認(rèn)的情況下也就是不存在活動(dòng)的profile(即不指定spring.profiles.active=?)時(shí),四種文件的加載優(yōu)先級(jí)依次為bootstrap.properties -> bootstrap.yml -> application.properties -> application.yml。感興趣可以在源碼上打斷點(diǎn)可以得知配置文件的加載分為兩次,如圖所示:
第一次是bootstrap(.properties/.yml)的加載:
以此得出加載優(yōu)先級(jí)bootstrap.properties -> bootstrap.yml
第二次是application(.properties/yml)的加載:
以此得出application.properties -> application.yml。
總結(jié):bootstrap的配置先于application的配置加載,同時(shí).properties的加載又先于.yml的加載,即加載優(yōu)先級(jí)bootstrap.properties -> bootstrap.yml -> application.properties -> application.yml。
需要注意的是:
1.當(dāng)同一個(gè)配置屬性在bootstrap.properties和bootstrap.yml文件中都存在時(shí),那么properties中的配置會(huì)被加載,而忽略yml文件中的配置(即優(yōu)先級(jí)高的配置覆蓋優(yōu)先級(jí)低的配置),不同配置相互互補(bǔ)。此處application(.properties/yml)同理。
2.但當(dāng)同一配置在bootstrap.properties和application.properties中都存在時(shí),那么雖然優(yōu)先加載bootstrap.properties但是會(huì)被applicatioin.properties中的配置覆蓋,此時(shí)則變成了低優(yōu)先級(jí)覆蓋高優(yōu)先的配置,所以網(wǎng)上很多文章所說(shuō)的高優(yōu)先級(jí)覆蓋低優(yōu)先級(jí)其實(shí)是不嚴(yán)謹(jǐn)?shù)摹?/p>
3.不同的配置會(huì)進(jìn)行互補(bǔ)操作,即SpringBoot會(huì)讀取全部的配置文件,加載所有不同的配置項(xiàng),匯成一個(gè)總的配置。
二、活動(dòng)的profile
例如在指定了spring.profiles.active=dev/test/prod此類時(shí),即有了活動(dòng)的profile時(shí),加載優(yōu)先級(jí)便會(huì)發(fā)生變化此時(shí)活動(dòng)的優(yōu)先級(jí)最高,還是直接上圖:
指定profile為dev
配置文件如上
看一下加載順序變成怎么樣的了,同樣第一次先加載bootstrap:
第二次加載application:
綜上此時(shí)的加載優(yōu)先級(jí)變?yōu)榱薭ootstrap-dev.yml -> bootstrap.properties -> application-dev.yml ->application.properties。且同屬性配置的覆蓋問(wèn)題和之前一樣,在同為bootstrap或同為application的情況下,優(yōu)先級(jí)高的覆蓋優(yōu)先級(jí)低的。但當(dāng)同時(shí)存在bootstrap和application時(shí)后者仍會(huì)覆蓋前者中的配置。
舉例1:假如此時(shí)只有bootstrap-dev.yml 和bootstrap.properties且存在相同配置,則使用bootstrap-dev.yml中的配置,此時(shí)遵循高優(yōu)先級(jí)覆蓋低優(yōu)先級(jí)。
舉例2:假如此時(shí)有bootstrap-dev.yml 、bootstrap.properties及application.properties且存在相同配置,則使用application.properties中的配置,遵循application覆蓋bootstrap原則,同樣此時(shí)變成了低優(yōu)先級(jí)覆蓋高優(yōu)先級(jí)。
三、使用外部配置
如項(xiàng)目使用nacos做配置中心,則存在相同配置時(shí)以nacos中配置為主(在沒(méi)有開啟本地覆蓋nacos遠(yuǎn)程配置的情況下),nacos中的配置將會(huì)覆蓋一切本地相同的配置,不同配置可以和本地進(jìn)行互補(bǔ)。
擴(kuò)展nacos開啟本地覆蓋遠(yuǎn)程配置
如果需要啟動(dòng)參數(shù)或者本地配置覆蓋遠(yuǎn)程配置,那么需要在遠(yuǎn)程配置里配置上允許重寫:
spring.cloud.config.allowOverride=true
但這是不夠的,盡管它開啟了總開關(guān),但是還有兩個(gè)默認(rèn)的小開關(guān)卡住了。
應(yīng)同時(shí)添加如下配置:
spring.cloud.config.overrideNone=true spring.cloud.config.overrideSystemProperties=false
第一個(gè)開關(guān)是遠(yuǎn)端不覆蓋本地?true 是的不覆蓋。
第二個(gè)開關(guān)是遠(yuǎn)端是否覆蓋系統(tǒng)配置?false 不覆蓋。 (默認(rèn)為true 覆蓋)
請(qǐng)注意,第一個(gè)小開關(guān)包括第二個(gè)。
overrideNone = true的話會(huì)開啟所有包括本地配置和系統(tǒng)配置并忽略掉overrideSystemProperties配置。
如果只想開啟overrideSystemProperties,那么就是overrideNone = false,overrideSystemProperties=false。
總結(jié)
到此這篇關(guān)于springBoot項(xiàng)目配置文件加載優(yōu)先級(jí)及同配置覆蓋問(wèn)題的文章就介紹到這了,更多相關(guān)springBoot配置文件加載優(yōu)先級(jí)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- SpringBoot中的配置文件加載優(yōu)先級(jí)詳解
- 關(guān)于SpringBoot配置文件加載位置的優(yōu)先級(jí)
- 一問(wèn)詳解SpringBoot配置文件優(yōu)先級(jí)
- Java springboot探究配置文件優(yōu)先級(jí)
- Java springboot 配置文件與多環(huán)境配置與運(yùn)行優(yōu)先級(jí)
- springboot如何查找配置文件路徑的順序和其優(yōu)先級(jí)別
- SpringBoot配置文件的優(yōu)先級(jí)順序、加載順序、bootstrap.yml與application.yml區(qū)別及說(shuō)明
相關(guān)文章
Java通過(guò)notify和wait實(shí)現(xiàn)線程間的通信功能
在軟件開發(fā)中,線程是實(shí)現(xiàn)并發(fā)執(zhí)行的重要手段,然而,線程之間的協(xié)作與通信卻是開發(fā)者必須重點(diǎn)考慮的挑戰(zhàn)之一,Java作為一種廣泛應(yīng)用于多線程編程的語(yǔ)言,本文將深入探討Java中通過(guò)notify和wait實(shí)現(xiàn)線程間通信的機(jī)制,需要的朋友可以參考下2024-06-06controller接口跳轉(zhuǎn)到另一個(gè)controller接口的實(shí)現(xiàn)
這篇文章主要介紹了controller接口跳轉(zhuǎn)到另一個(gè)controller接口的實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-09-09淺談Java中ThreadLocal引發(fā)的內(nèi)存泄漏
本文主要介紹了淺談Java中ThreadLocal引發(fā)的內(nèi)存泄漏,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-06-06java實(shí)現(xiàn)幸運(yùn)抽獎(jiǎng)系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)幸運(yùn)抽獎(jiǎng)系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-07-07ssm框架Springmvc文件上傳實(shí)現(xiàn)代碼詳解
這篇文章主要介紹了ssm框架Springmvc文件上傳實(shí)現(xiàn)代碼詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-07-07javaweb實(shí)戰(zhàn)之商城項(xiàng)目開發(fā)(二)
這篇文章主要針對(duì)javaweb商城項(xiàng)目開發(fā)進(jìn)行實(shí)戰(zhàn)演習(xí),利用mybatis創(chuàng)建DAO層,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-02-02java ThreadPoolExecutor 并發(fā)調(diào)用實(shí)例詳解
這篇文章主要介紹了java ThreadPoolExecutor 并發(fā)調(diào)用實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下2017-05-05