做者:廢物大師兄
來源:www.cnblogs.com/cjsblog/p/14007311.htmlhtml
本文探討Nacos做爲配置中心,如何實現不一樣環境(開發、測試、灰度、正式)的配置管理問題。java
就像Maven用groupId、artifactId、version三者來定位jar包在倉庫中的位置同樣,Nacos也提供了 Namespace (命名空間) 、Data ID (配置集ID)、 Group (組) 來肯定一個配置文件(或者叫配置集)。web
由此,實現多環境配置的方案也有三種:spring
一、用命名空間(namespace)來區分不一樣的環境,一個命名空間對應一個環境;apache
二、用配置組(group)來區分不一樣的環境,命名空間用默認的public便可,一個組對應一種環境;bootstrap
三、用配置集ID(Data ID)名稱來區分不一樣的環境,命名空間和組用默認的便可,經過文件命名來區分;intellij-idea
接下來,逐個來看app
http://{host}:{port}/nacosmaven
http://{host}:{port}/nacos/index.htmlide
默認用戶名密碼都是nacos
爲了方便演示,這裏建了一個名爲example的Spring Boot項目
pom.xml
1 <?xml version="1.0" encoding="UTF-8"?> 2 <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 3 xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/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命名來區分環境,命名空間和組默認便可
在 Nacos Spring Cloud 中,dataId 的完整格式以下:
${prefix}-${spring.profiles.active}.${file-extension}
用命令行啓動也是同樣的
例如:
java -Dspring.profiles.active=test -jar example-0.0.1-SNAPSHOT.jar
項目不變,咱們把spring.application.name改爲example2
命名空間用默認的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
若是是這樣的話,這個時候,Data ID 命名就應該是 example2-test.yaml
建立命名空間的時候,若是不指定ID,則自動生成的id就是這樣的uuid字符串,咱們仍是本身指定一個有意義的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
第一種,用 Data ID 區分環境,雖然簡單,可是每一個項目要建立4個配置文件,隨着項目的增多,都在一個命名空間下回顯得很混亂,查找起來也不是很方便,並且不利於作權限控制
第二種,用Group區分,問題也是同樣的
綜上,最好的是用Namespace區分環境,清晰明瞭,並且有利於作權限控制
近期熱文推薦:
1.Java 15 正式發佈, 14 個新特性,刷新你的認知!!
2.終於靠開源項目弄到 IntelliJ IDEA 激活碼了,真香!
3.我用 Java 8 寫了一段邏輯,同事直呼看不懂,你試試看。。
以爲不錯,別忘了隨手點贊+轉發哦!