本文探討一下如何實現不同環境(開發、測試、灰度、正式)的配置管理問題。
就像Maven用groupId、artifactId、version三者來定位jar包在倉庫中的位置一樣,Nacos也提供了 Namespace (命名空間) 、Data ID (配置集ID)、 Group (組) 來確定一個配置文件(或者叫配置集)。
由此,實現多環境配置的方案也有三種:
1、用命名空間(namespace)來區分不同的環境,一個命名空間對應一個環境;
2、用配置組(group)來區分不同的環境,命名空間用默認的public即可,一個組對應一種環境;
3、用配置集ID(Data ID)名稱來區分不同的環境,命名空間和組用默認的即可,通過文件命名來區分;
接下來,逐個來看
http://{host}:{port}/nacos
http://{host}:{port}/nacos/index.html
默認用戶名密碼都是nacos
為了方便演示,這里建了一個名為example的Spring Boot項目
bootstrap.yml
spring:
application:
name: example
cloud:
nacos:
config:
server-addr: 192.168.100.10:8848
file-extension: yaml
- 利用 Data ID 命名 來區分環境
利用Data ID命名來區分環境,命名空間和組默認即可
在 Nacos Spring Cloud 中,dataId 的完整格式如下:
${prefix}-${spring.profiles.active}.${file-extension}
prefix 默認為 spring.application.name 的值,也可以通過配置項 spring.cloud.nacos.config.prefix來配置
spring.profiles.active 即為當前環境對應的 profile,詳情可以參考 Spring Boot文檔。 注意:當 spring.profiles.active 為空時,對應的連接符 - 也將不存在,dataId 的拼接格式變成 ${prefix}.${file-extension}
file-exetension 為配置內容的數據格式,可以通過配置項 spring.cloud.nacos.config.file-extension 來配置。目前只支持 properties 和 yaml 類型。
用命令行啟動也是一樣的
例如:
java -Dspring.profiles.active=test -jar example-0.0.1-SNAPSHOT.jar
2. 利用 Group 來區分環境
項目不變,我們把spring.application.name改成example2
命名空間用默認的public
java -Dspring.cloud.nacos.config.group=DEV_GROUP -jar example-0.0.1-SNAPSHOT.jar
- 利用 Namespace 區分環境
創建命名空間的時候,如果不指定ID,則自動生成的id就是這樣的uuid字符串,我們還是自己指定一個有意義的ID吧
java -Dspring.cloud.nacos.config.namespace=ns_dev -jar example-0.0.1-SNAPSHOT.jar
java -Dspring.profiles.active=test
-Dspring.cloud.nacos.config.namespace=ns_test
-Dspring.cloud.nacos.config.group=TEST_GROUP
-jar example-0.0.1-SNAPSHOT.jar
4. 小結
第一種,用 Data ID 區分環境,雖然簡單,但是每個項目要創建4個配置文件,隨着項目的增多,都在一個命名空間下會顯得很混亂,查找起來也不是很方便,而且不利於做權限控制
第二種,用Group區分,問題也是一樣的
綜上,最好的是用Namespace區分環境,清晰明了,而且有利於做權限控制