老板都闭口了,我能说不么?

本文探讨一下如何实现不同环境(开发、测试、灰度、正式)的配置管理问题。

就像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")@RefreshScopepublic 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万+码农成长充电第一站,陪有幻想的你一起成长