用了3年Apollo,这次我选择了Nacos,原因不多说了

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

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

就像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
用了3年Apollo,这次我选择了Nacos,原因不多说了_第1张图片
pom.xml

1 
 2 
 4     4.0.0
 5     
 6         org.springframework.boot
 7         spring-boot-starter-parent
 8         2.3.6.RELEASE
 9          
10     
11     com.example
12     example
13     0.0.1-SNAPSHOT
14     example
15 
16     
17         1.8
18         2.2.3.RELEASE
19     
20 
21     
22         
23             org.springframework.boot
24             spring-boot-starter-web
25         
26         
27             com.alibaba.cloud
28             spring-cloud-starter-alibaba-nacos-config
29         
30     
31 
32     
33         
34             
35                 com.alibaba.cloud
36                 spring-cloud-alibaba-dependencies
37                 ${spring-cloud-alibaba.version}
38                 pom
39                 import
40             
41         
42     
43 
44     
45         
46             
47                 org.springframework.boot
48                 spring-boot-maven-plugin
49             
50         
51     
52 
53  

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 类型。
    用了3年Apollo,这次我选择了Nacos,原因不多说了_第2张图片
    例如:
java -Dspring.profiles.active=test -jar example-0.0.1-SNAPSHOT.jar 

在这里插入图片描述
2.利用 Group 来区分环境

项目不变,我们把spring.application.name改成example2

命名空间用默认的public
用了3年Apollo,这次我选择了Nacos,原因不多说了_第3张图片

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 区分环境
用了3年Apollo,这次我选择了Nacos,原因不多说了_第4张图片

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
用了3年Apollo,这次我选择了Nacos,原因不多说了_第5张图片
欢迎关注我的微信公众号「码农突围」,分享Python、Java、大数据、机器学习、人工智能等技术,关注码农技术提升•职场突围•思维跃迁,20万+码农成长充电第一站,陪有梦想的你一起成长

你可能感兴趣的:(nacos)