摘要:通過拆分這兩類配置內容,希望可以做到配置的共享加載與統一管理。共享配置通過上面加載多個配置的實現,實際上我們已經可以實現不同應用共享配置了。
前情回顧:
《Spring Cloud Alibaba基礎教程:使用Nacos實現服務注冊與發現》
《Spring Cloud Alibaba基礎教程:支持的幾種服務消費方式》
《Spring Cloud Alibaba基礎教程:使用Nacos作為配置中心》
《Spring Cloud Alibaba基礎教程:Nacos配置的加載規則詳解》
《Spring Cloud Alibaba基礎教程:Nacos配置的多環境管理》
對于Nacos作為配置中心的使用,通過之前的幾篇博文,我們已經介紹了如何在Nacos中創建配置內容、Nacos配置內容與Spring應用配置之間的對應關系以及實戰中多環境下的配置管理方案。
但是,我們實際應用過程中還會經常碰到這樣的問題:有時候我們會對應用的配置根據具體作用做一些拆分,存儲在不同的配置文件中,除了歸類不同的配置之外,也可以便于共享配置給不同的應用。對于這樣的需求,Nacos也可以很好的支持,下面就來具體介紹一下,當使用Nacos時,我們如何加載多個配置,以及如何共享配置。
加載多個配置通過之前的學習,我們已經知道Spring應用對Nacos中配置內容的對應關系是通過下面三個參數控制的:
spring.cloud.nacos.config.prefix
spring.cloud.nacos.config.file-extension
spring.cloud.nacos.config.group
默認情況下,會加載Data ID=${spring.application.name}.properties,Group=DEFAULT_GROUP的配置。
假設現在有這樣的一個需求:我們想要對所有應用的Actuator模塊以及日志輸出做統一的配置管理。所以,我們希望可以將Actuator模塊的配置放在獨立的配置文件actuator.properties文件中,而對于日志輸出的配置放在獨立的配置文件log.properties文件中。通過拆分這兩類配置內容,希望可以做到配置的共享加載與統一管理。
這時候,我們只需要做以下兩步,就可以實現這個需求:
第一步:在Nacos中創建Data ID=actuator.properties,Group=DEFAULT_GROUP和Data ID=log.properties,Group=DEFAULT_GROUP的配置內容。
第二步:在Spring Cloud應用中通過使用spring.cloud.nacos.config.ext-config參數來配置要加載的這兩個配置內容,比如:
spring.cloud.nacos.config.ext-config[0].data-id=actuator.properties spring.cloud.nacos.config.ext-config[0].group=DEFAULT_GROUP spring.cloud.nacos.config.ext-config[0].refresh=true spring.cloud.nacos.config.ext-config[1].data-id=log.properties spring.cloud.nacos.config.ext-config[1].group=DEFAULT_GROUP spring.cloud.nacos.config.ext-config[1].refresh=true
可以看到,spring.cloud.nacos.config.ext-config配置是一個數組List類型。每個配置中包含三個參數:data-id、group,refresh;前兩個不做贅述,與Nacos中創建的配置相互對應,refresh參數控制這個配置文件中的內容時候支持自動刷新,默認情況下,只有默認加載的配置才會自動刷新,對于這些擴展的配置加載內容需要配置該設置時候才會實現自動刷新。
共享配置通過上面加載多個配置的實現,實際上我們已經可以實現不同應用共享配置了。但是Nacos中還提供了另外一個便捷的配置方式,比如下面的設置與上面使用的配置內容是等價的:
spring.cloud.nacos.config.shared-dataids=actuator.properties,log.properties spring.cloud.nacos.config.refreshable-dataids=actuator.properties,log.properties
spring.cloud.nacos.config.shared-dataids參數用來配置多個共享配置的Data Id,多個的時候用用逗號分隔
spring.cloud.nacos.config.refreshable-dataids參數用來定義哪些共享配置的Data Id在配置變化時,應用中可以動態刷新,多個Data Id之間用逗號隔開。如果沒有明確配置,默認情況下所有共享配置都不支持動態刷新
配置加載的優先級當我們加載多個配置的時候,如果存在相同的key時,我們需要深入了解配置加載的優先級關系。
在使用Nacos配置的時候,主要有以下三類配置:
A: 通過spring.cloud.nacos.config.shared-dataids定義的共享配置
B: 通過spring.cloud.nacos.config.ext-config[n]定義的加載配置
C: 通過內部規則(spring.cloud.nacos.config.prefix、spring.cloud.nacos.config.file-extension、spring.cloud.nacos.config.group這幾個參數)拼接出來的配置
要弄清楚這幾個配置加載的順序,我們從日志中也可以很清晰的看到,我們可以做一個簡單的實驗:
spring.cloud.nacos.config.ext-config[0].data-id=actuator.properties spring.cloud.nacos.config.ext-config[0].group=DEFAULT_GROUP spring.cloud.nacos.config.ext-config[0].refresh=true spring.cloud.nacos.config.shared-dataids=log.properties spring.cloud.nacos.config.refreshable-dataids=log.properties
根據上面的配置,應用分別會去加載三類不同的配置文件,啟動應用的時候,將會在日志中看到如下輸出:
2019-02-08 21:23:02.665 INFO 63804 --- [main] o.s.c.a.n.c.NacosPropertySourceBuilder : Loading nacos data, dataId: "log.properties", group: "DEFAULT_GROUP" 2019-02-08 21:23:02.671 INFO 63804 --- [main] o.s.c.a.n.c.NacosPropertySourceBuilder : Loading nacos data, dataId: "actuator.properties", group: "DEFAULT_GROUP" 2019-02-08 21:23:02.677 INFO 63804 --- [main] o.s.c.a.n.c.NacosPropertySourceBuilder : Loading nacos data, dataId: "alibaba-nacos-config-client.properties", group: "DEFAULT_GROUP"
后面加載的配置會覆蓋之前加載的配置,所以優先級關系是:A < B < C
參考資料Nacos官方文檔
代碼示例本文示例讀者可以通過查看下面倉庫的中的alibaba-nacos-config-client項目:
Github:https://github.com/dyc87112/SpringCloud-Learning/
Gitee:https://gitee.com/didispace/SpringCloud-Learning/
如果您對這些感興趣,歡迎star、follow、收藏、轉發給予支持!
以下專題教程也許您會有興趣Spring Boot基礎教程
Spring Cloud基礎教程
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/77421.html
摘要:之前開放過一臺公益給大家,以方便大家在閱讀我博客中教程時候做實驗。由于目前在連載,所以對應的也部署了一臺,并且也開放出來,給大家學習測試之用。 之前開放過一臺公益Eureka Server給大家,以方便大家在閱讀我博客中教程時候做實驗。由于目前在連載Spring Cloud Alibaba,所以對應的也部署了一臺Nacos,并且也開放出來,給大家學習測試之用。 Nacos控制臺 ...
摘要:在搭建集群之前,我們需要先修改的數據持久化配置為存儲。所以,如果啟動多個默認配置下的節點,數據存儲是存在一致性問題的。為了解決這個問題,采用了集中式存儲的方式來支持集群化部署,目前只要支持的存儲。 前情回顧: 《Spring Cloud Alibaba基礎教程:使用Nacos實現服務注冊與發現》 《Spring Cloud Alibaba基礎教程:支持的幾種服務消費方式》 《Spri...
摘要:下表整理了目前的版本與版本的兼容關系還未所以,不論您是在讀我的基礎教程基礎教程還是正在連載的系列教程。 這篇博文是臨時增加出來的內容,主要是由于最近連載《Spring Cloud Alibaba基礎教程》系列的時候,碰到讀者咨詢的大量問題中存在一個比較普遍的問題:版本的選擇。其實這類問題,在之前寫Spring Cloud基礎教程的時候,就已經發過一篇《聊聊Spring Cloud版本的...
摘要:下面通過這篇,詳細介紹當使用作為配置中心之后,如何實現中修改規則同步到。關于下面改造的原理和分析可以見上一篇中修改規則同步到的頭兩節內容,這里不重復介紹了。但是由于考慮到與的結合使用,略作修改。主要就是中存儲配置的和不要弄錯。 上一篇我們介紹了如何通過改造Sentinel Dashboard來實現修改規則之后自動同步到Apollo。下面通過這篇,詳細介紹當使用Nacos作為配置中心之后...
摘要:最近對基礎教程系列的催更比較多,說一下最近的近況因為打算一起更新。再次,對于中國用戶來說,還有一個非常特殊的意義它將曾經紅極一時的,以及阿里巴巴的強力消息中間件融入體系。 最近對《Spring Cloud Alibaba基礎教程》系列的催更比較多,說一下最近的近況:因為打算Spring Boot 2.x一起更新。所以一直在改博客Spring Boot專題頁和Git倉庫的組織。由于前端技...
閱讀 1675·2019-08-30 12:51
閱讀 662·2019-08-29 17:30
閱讀 3700·2019-08-29 15:17
閱讀 859·2019-08-28 18:10
閱讀 1365·2019-08-26 17:08
閱讀 2174·2019-08-26 12:16
閱讀 3438·2019-08-26 11:47
閱讀 3505·2019-08-23 16:18