老板都闭口了,我能说不么?
本文探讨一下如何实现不同环境(开发、测试、灰度、正式)的配置管理问题。
就像 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 我的项目
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;}
}
1. 利用 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}.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
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
3. 利用 Namespace 辨别环境
创立命名空间的时候,如果不指定 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
4. 小结
第一种,用 Data ID 辨别环境,尽管简略,然而每个我的项目要创立 4 个配置文件,随着我的项目的增多,都在一个命名空间下回显得很凌乱,查找起来也不是很不便,而且不利于做权限管制
第二种,用 Group 辨别,问题也是一样的
综上,最好的是用 Namespace 辨别环境,清晰明了,而且有利于做权限管制
起源 | https://urlify.cn/jmY3Ez
欢送关注我的微信公众号「码农解围」,分享 Python、Java、大数据、机器学习、人工智能等技术,关注码农技术晋升•职场解围•思维跃迁,20 万 + 码农成长充电第一站,陪有幻想的你一起成长