Spring Cloud Alibaba基礎(chǔ)教程:Nacos配置的多環(huán)境管理

前情回顧:

通過之前兩篇對Nacos配置管理功能的介紹,已經(jīng)學會了在Nacos中如何加入配置以及Spring Cloud應(yīng)用如何通過配置來加載到對應(yīng)的內(nèi)容。接下來,我們討論一個在使用配置中心時,都需要關(guān)注的一個問題:多環(huán)境的配置如何實現(xiàn)與管理?

多環(huán)境管理

在Nacos中,本身有多個不同管理級別的概念,包括:Data IDGroup、Namespace。只要利用好這些層級概念的關(guān)系,就可以根據(jù)自己的需要來實現(xiàn)多環(huán)境的管理。

下面,我就來介紹一下,可以使用的幾種實現(xiàn)方式:

使用Data IDprofiles實現(xiàn)

Data ID在Nacos中,我們可以理解為就是一個Spring Cloud應(yīng)用的配置文件名。通過上一篇《Spring Cloud Alibaba基礎(chǔ)教程:Nacos配置的加載規(guī)則詳解》,我們知道默認情況下Data ID的名稱格式是這樣的:${spring.application.name}.properties,即:以Spring Cloud應(yīng)用命名的properties文件。

實際上,Data ID的規(guī)則中,還包含了環(huán)境邏輯,這一點與Spring Cloud Config的設(shè)計類似。我們在應(yīng)用啟動時,可以通過spring.profiles.active來指定具體的環(huán)境名稱,此時客戶端就會把要獲取配置的Data ID組織為:${spring.application.name}-${spring.profiles.active}.properties

實際上,更原始且最通用的匹配規(guī)則,是這樣的:${spring.cloud.nacos.config.prefix}-${spring.profile.active}.${spring.cloud.nacos.config.file-extension}。而上面的結(jié)果是因為${spring.cloud.nacos.config.prefix}${spring.cloud.nacos.config.file-extension}都使用了默認值。

動手試一試

我們可以用《Spring Cloud Alibaba基礎(chǔ)教程:使用Nacos作為配置中心》一文中的列子(可在文末倉庫中獲取)為基礎(chǔ),體驗一下這種區(qū)分環(huán)境的配置方式。

第一步:先在Nacos中,根據(jù)這個規(guī)則,創(chuàng)建兩個不同環(huán)境的配置內(nèi)容。比如:

image.png

如上圖,我們?yōu)?code>alibaba-nacos-config-client應(yīng)用,定義了DEV和TEST的兩個獨立的環(huán)境配置。我們可以在里面定義不同的內(nèi)容值,以便后續(xù)驗證是否真實加載到了正確的配置。

第二步:在alibaba-nacos-config-client應(yīng)用的配置文件中,增加環(huán)境配置:spring.profiles.active=DEV

第三步:啟動應(yīng)用,我們可以看到日志中打印了,加載的配置文件:

2019-01-30 15:25:18.216  INFO 96958 --- [           main] o.s.c.a.n.c.NacosPropertySourceBuilder   : Loading nacos data, dataId: 'alibaba-nacos-config-client-DEV.properties', group: 'DEFAULT_GROUP'

使用Group實現(xiàn)

Group在Nacos中是用來對Data ID做集合管理的重要概念。所以,如果我們把一個環(huán)境的配置視為一個集合,那么也就可以實現(xiàn)不同環(huán)境的配置管理。對于Group的用法并沒有固定的規(guī)定,所以我們在實際使用的時候,需要根據(jù)我們的具體需求,可以是架構(gòu)運維上對多環(huán)境的管理,也可以是業(yè)務(wù)上對不同模塊的參數(shù)管理。為了避免沖突,我們需要在架構(gòu)設(shè)計之初,做好一定的規(guī)劃。這里,我們先來說說如何用Group來實現(xiàn)多環(huán)境配置管理的具體實現(xiàn)方式。

動手試一試

第一步:先在Nacos中,通過區(qū)分Group來創(chuàng)建兩個不同環(huán)境的配置內(nèi)容。比如:

image.png

如上圖,我們?yōu)?code>alibaba-nacos-config-client應(yīng)用,定義了DEV環(huán)境和TEST環(huán)境的兩個獨立的配置,這兩個匹配與上一種方法不同,它們的Data ID是完全相同的,只是GROUP不同。

第二步:在alibaba-nacos-config-client應(yīng)用的配置文件中,增加Group的指定配置:spring.cloud.nacos.config.group=DEV_GROUP

第三步:啟動應(yīng)用,我們可以看到日志中打印了,加載的配置文件:

2019-01-30 15:55:23.718  INFO 3216 --- [main] o.s.c.a.n.c.NacosPropertySourceBuilder   : Loading nacos data, dataId: 'alibaba-nacos-config-client.properties', group: 'DEV_GROUP'

使用Namespace實現(xiàn)

Namespace在本系列教程中,應(yīng)該還是第一次出現(xiàn)。先來看看官方的概念說明:用于進行租戶粒度的配置隔離。不同的命名空間下,可以存在相同的GroupData ID的配置。Namespace的常用場景之一是不同環(huán)境的配置的區(qū)分隔離,例如:開發(fā)測試環(huán)境和生產(chǎn)環(huán)境的資源(如配置、服務(wù))隔離等。

在官方的介紹中,就介紹了利用其可以作為環(huán)境的隔離使用,下面我們就來試一下吧!

動手試一試

第一步:先在Nacos中,根據(jù)環(huán)境名稱來創(chuàng)建多個Namespace。比如:

image.png

第二步:在配置列表的最上方,可以看到除了Public之外,多了幾個剛才創(chuàng)建的Namepsace。分別在DEVTEST空間下為alibaba-nacos-config-client應(yīng)用創(chuàng)建配置內(nèi)容:

image.png

第三步:在alibaba-nacos-config-client應(yīng)用的配置文件中,增加Namespace的指定配置,比如:spring.cloud.nacos.config.namespace=83eed625-d166-4619-b923-93df2088883a。

這里需要注意namespace的配置不是使用名稱,而是使用Namespace的ID。

第四步:啟動應(yīng)用,通過訪問localhost:8001/test接口,驗證一下返回內(nèi)容是否正確。這種方式下,目前版本的日志并不會輸出與Namespace相關(guān)的信息,所以還無法以此作為加載內(nèi)容的判斷依據(jù)。

深入思考

上面我們分別利用Nacos配置管理功能中的幾個不同緯度來實現(xiàn)多環(huán)境的配置管理。從結(jié)果上而言,不論用哪一種方式,都能夠勝任需求,但是哪一種最好呢?

第一種:通過Data IDprofile實現(xiàn)。

  • 優(yōu)點:這種方式與Spring Cloud Config的實現(xiàn)非常像,用過Spring Cloud Config的用戶,可以毫無違和感的過渡過來,由于命名規(guī)則類似,所以要從Spring Cloud Config中做遷移也非常簡單。
  • 缺點:這種方式在項目與環(huán)境多的時候,配置內(nèi)容就會顯得非?;靵y。配置列表中會看到各種不同應(yīng)用,不同環(huán)境的配置交織在一起,非常不利于管理。
  • 建議:項目不多時使用,或者可以結(jié)合Group對項目根據(jù)業(yè)務(wù)或者組織架構(gòu)做一些拆分規(guī)劃。

第二種:通過Group實現(xiàn)。

  • 優(yōu)點:通過Group按環(huán)境講各個應(yīng)用的配置隔離開??梢苑浅7奖愕睦?code>Data ID和Group的搜索功能,分別從應(yīng)用緯度和環(huán)境緯度來查看配置。
  • 缺點:由于會占用Group緯度,所以需要對Group的使用做好規(guī)劃,畢竟與業(yè)務(wù)上的一些配置分組起沖突等問題。
  • 建議:這種方式雖然結(jié)構(gòu)上比上一種更好一些,但是依然可能會有一些混亂,主要是在Group的管理上要做好規(guī)劃和控制。

第三種:通過Namespace實現(xiàn)。

  • 優(yōu)點:官方建議的方式,通過Namespace來區(qū)分不同的環(huán)境,釋放了Group的自由度,這樣可以讓Group的使用專注于做業(yè)務(wù)層面的分組管理。同時,Nacos控制頁面上對于Namespace也做了分組展示,不需要搜索,就可以隔離開不同的環(huán)境配置,非常易用。
  • 缺點:沒有啥缺點,可能就是多引入一個概念,需要用戶去理解吧。
  • 建議:直接用這種方式長遠上來說會比較省心。雖然可能對小團隊而言,項目不多,第一第二方式也夠了,但是萬一后面做大了呢?

注意:不論用哪一種方式實現(xiàn)。對于指定環(huán)境的配置(spring.profiles.active=DEV、spring.cloud.nacos.config.group=DEV_GROUP、spring.cloud.nacos.config.namespace=83eed625-d166-4619-b923-93df2088883a),都不要配置在應(yīng)用的bootstrap.properties中。而是在發(fā)布腳本的啟動命令中,用-Dspring.profiles.active=DEV的方式來動態(tài)指定,會更加靈活!。

參考資料

代碼示例

本文示例讀者可以通過查看下面?zhèn)}庫的中的alibaba-nacos-config-client項目:

如果您對這些感興趣,歡迎star、follow、收藏、轉(zhuǎn)發(fā)給予支持!

連載目錄

以下專題教程也許您會有興趣

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容