- 1. 利用 Data ID 命名 來(lái)區(qū)分環(huán)境
- 2. 利用 Group 來(lái)區(qū)分環(huán)境
- 3. 利用 Namespace 區(qū)分環(huán)境
老板都開口了,我能說不么?
友情提示:在實(shí)際項(xiàng)目中使用,更加推薦使用 Apollo 做配置中心。
相比來(lái)說,Apollo 在企業(yè)級(jí)落地上,會(huì)比 Nacos 至少好一個(gè) Level。例如說權(quán)限、灰度、發(fā)布審核等等。
本文探討一下如何實(shí)現(xiàn)不同環(huán)境(開發(fā)、測(cè)試、灰度、正式)的配置管理問題。
就像Maven用groupId、artifactId、version三者來(lái)定位jar包在倉(cāng)庫(kù)中的位置一樣,Nacos也提供了 Namespace (命名空間) 、Data ID (配置集ID)、 Group (組) 來(lái)確定一個(gè)配置文件(或者叫配置集)。
由此,實(shí)現(xiàn)多環(huán)境配置的方案也有三種:
1、用命名空間(namespace)來(lái)區(qū)分不同的環(huán)境,一個(gè)命名空間對(duì)應(yīng)一個(gè)環(huán)境;
2、用配置組(group)來(lái)區(qū)分不同的環(huán)境,命名空間用默認(rèn)的public即可,一個(gè)組對(duì)應(yīng)一種環(huán)境;
3、用配置集ID(Data ID)名稱來(lái)區(qū)分不同的環(huán)境,命名空間和組用默認(rèn)的即可,通過文件命名來(lái)區(qū)分;
接下來(lái),逐個(gè)來(lái)看
http://{host}:{port}/nacos
http://{host}:{port}/nacos/index.html
默認(rèn)用戶名密碼都是nacos
圖片為了方便演示,這里建了一個(gè)名為example的Spring Boot項(xiàng)目
圖片pom.xml
1 <?xml version='1.0' encoding='UTF-8'?>
2 <project xmlns='http://maven./POM/4.0.0' xmlns:xsi='http://www./2001/XMLSchema-instance'
3 xsi:schemaLocation='http://maven./POM/4.0.0 https://maven./xsd/maven-4.0.0.xsd'>
4 <modelVersion>4.0.0</modelVersion>
5 <parent>
6 <groupId>org.springframework.boot</groupId>
7 <artifactId>spring-boot-starter-parent</artifactId>
8 <version>2.3.6.RELEASE</version>
9 <relativePath/> <!-- lookup parent from repository -->
10 </parent>
11 <groupId>com.example</groupId>
12 <artifactId>example</artifactId>
13 <version>0.0.1-SNAPSHOT</version>
14 <name>example</name>
15
16 <properties>
17 <java.version>1.8</java.version>
18 <spring-cloud-alibaba.version>2.2.3.RELEASE</spring-cloud-alibaba.version>
19 </properties>
20
21 <dependencies>
22 <dependency>
23 <groupId>org.springframework.boot</groupId>
24 <artifactId>spring-boot-starter-web</artifactId>
25 </dependency>
26 <dependency>
27 <groupId>com.alibaba.cloud</groupId>
28 <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
29 </dependency>
30 </dependencies>
31
32 <dependencyManagement>
33 <dependencies>
34 <dependency>
35 <groupId>com.alibaba.cloud</groupId>
36 <artifactId>spring-cloud-alibaba-dependencies</artifactId>
37 <version>${spring-cloud-alibaba.version}</version>
38 <type>pom</type>
39 <scope>import</scope>
40 </dependency>
41 </dependencies>
42 </dependencyManagement>
43
44 <build>
45 <plugins>
46 <plugin>
47 <groupId>org.springframework.boot</groupId>
48 <artifactId>spring-boot-maven-plugin</artifactId>
49 </plugin>
50 </plugins>
51 </build>
52
53 </project>
bootstrap.yml
spring:
application:
name: example
cloud:
nacos:
config:
server-addr: 192.168.100.10:8848
file-extension: yaml
HelloController.java
package com.example.controller;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.cloud.context.config.annotation.RefreshScope;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
/**
* @author ChengJianSheng
* @data 2020/11/19
*/
@RestController
@RequestMapping('/hello')
@RefreshScope
public class HelloController {
@Value('${greet.hello}')
private String greet;
@GetMapping('/sayHi')
public String sayHi() {
return greet;
}
}
利用Data ID命名來(lái)區(qū)分環(huán)境,命名空間和組默認(rèn)即可
在 Nacos Spring Cloud 中,dataId 的完整格式如下:
${prefix}-${spring.profiles.active}.${file-extension}
- prefix 默認(rèn)為 spring.application.name 的值,也可以通過配置項(xiàng) spring.cloud.nacos.config.prefix來(lái)配置
- spring.profiles.active 即為當(dāng)前環(huán)境對(duì)應(yīng)的 profile,詳情可以參考 Spring Boot文檔。注意:當(dāng) spring.profiles.active 為空時(shí),對(duì)應(yīng)的連接符 - 也將不存在,dataId 的拼接格式變成 {file-extension}
- file-exetension 為配置內(nèi)容的數(shù)據(jù)格式,可以通過配置項(xiàng) spring.cloud.nacos.config.file-extension 來(lái)配置。目前只支持 properties 和 yaml 類型。
圖片圖片圖片圖片圖片用命令行啟動(dòng)也是一樣的
圖片例如:
java -Dspring.profiles.active=test -jar example-0.0.1-SNAPSHOT.jar
圖片項(xiàng)目不變,我們把spring.application.name改成example2
命名空間用默認(rèn)的public
圖片圖片圖片java -Dspring.cloud.nacos.config.group=DEV_GROUP -jar example-0.0.1-SNAPSHOT.jar
圖片java -Dspring.cloud.nacos.config.group=TEST_GROUP -jar example-0.0.1-SNAPSHOT.jar
圖片java -Dspring.profiles.active=test -Dspring.cloud.nacos.config.group=TEST_GROUP -jar example-0.0.1-SNAPSHOT.jar
如果是這樣的話,這個(gè)時(shí)候,Data ID 命名就應(yīng)該是 example2-test.yaml
圖片創(chuàng)建命名空間的時(shí)候,如果不指定ID,則自動(dòng)生成的id就是這樣的uuid字符串,我們還是自己指定一個(gè)有意義的ID吧
圖片圖片圖片圖片圖片圖片圖片java -Dspring.cloud.nacos.config.namespace=ns_dev -jar example-0.0.1-SNAPSHOT.jar
圖片java -Dspring.profiles.active=dev -Dspring.cloud.nacos.config.namespace=ns_dev -jar example-0.0.1-SNAPSHOT.jar
圖片java -Dspring.cloud.nacos.config.namespace=ns_test -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. 小結(jié)
第一種,用 Data ID 區(qū)分環(huán)境,雖然簡(jiǎn)單,但是每個(gè)項(xiàng)目要?jiǎng)?chuàng)建4個(gè)配置文件,隨著項(xiàng)目的增多,都在一個(gè)命名空間下回顯得很混亂,查找起來(lái)也不是很方便,而且不利于做權(quán)限控制
第二種,用Group區(qū)分,問題也是一樣的
綜上,最好的是用Namespace區(qū)分環(huán)境,清晰明了,而且有利于做權(quán)限控制