Nacos Namespace/Group/DataID三者关系解读
作者:91猿说编程
命名空间(Namespace)
用于进行租户粒度的配置隔离。不同的命名空间下,可以存在相同的 Group 或 Data ID 的配置。
Namespace 的常用场景之一是不同环境的配置的区分隔离,例如开发测试环境和生产环境的资源(如配置、服务)隔离等。
配置分组(Group)
Nacos 中的一组配置集,是组织配置的维度之一。
通过一个有意义的字符串(如 Buy 或 Trade )对配置集进行分组,从而区分 Data ID 相同的配置集。
当您在 Nacos 上创建一个配置时,如果未填写配置分组的名称,则配置分组的名称默认采用 DEFAULT_GROUP 。
配置分组的常见场景:不同的应用或组件使用了相同的配置类型,如 database_url 配置和 MQ_topic 配置。
配置集 ID(Data ID)
Nacos 中的某个配置集的 ID。配置集 ID 是组织划分配置的维度之一。
Data ID 通常用于组织划分系统的配置集。一个系统或者应用可以包含多个配置集,每个配置集都可以被一个有意义的名称标识。
Data ID 通常采用类 Java 包(如 com.taobao.tc.refund.log.level)的命名规则保证全局唯一性。此命名规则非强制。
配置集:一组相关或者不相关的配置项的集合称为配置集。
在系统中,一个配置文件通常就是一个配置集,包含了系统各个方面的配置。
例如,一个配置集可能包含了数据源、线程池、日志级别等配置项。
三者关系
这三者的关系类似于Java里面的package名和类名,最外层的Namespace是可以用于区分部署环境的,Group和DataID逻辑上区分两个目标对象。
默认情况
Namespace=public,Group=DEFAULT_GROUP,默认Cluster是DEFAULT
具体情况
Nacos默认的命名空间是public,我们就可以利用Namespace来实现隔离,比如我们现在有三个环境:开发、测试、生产环境,我们就可以创建三个Namespace,不同的N amespace之间是隔离的。
Group本身就是分组的意思,它可以把不同的微服务划分到同一个分组里面去。
剩下的就是具体微服务,一个Service可以包含多个Cluster,Nacos默认Cluster是DEFAULT,Cluster是对指定微服务的一个虚拟划分。
比如说,将一个Service部署在北京和和杭州的机房中,北京机房的Service就可以起名为(BJ),杭州机房中的Service就可以起名为(HZ),这样就可以尽量让同一个机房的微服务互相调用,提升性能。
切换不同环境
1. DataID方案
指定spring.profile.active和配置文件的DataID来使不同环境下读取不同的配置,配置规则:默认空间+新建dev和test两个DataId:
- 新建dev配置DataID(已经创建完成)
- 新建test配置DataID
2. Group方案
新建配置的时候填入分组DEV_GROUP
同样的方式在建立一个同名的dataId分组为TEST_GROUP
这里相当于相同的目录下不同的文件
- 项目配置bootstrap.properties
spring.application.name=nacos-config-client spring.cloud.nacos.discovery.server-addr=192.168.43.11:8848 # Nacos作为配置中心地址 spring.cloud.nacos.config.server-addr=192.168.43.11:8848 # 指定yaml格式的配置 spring.cloud.nacos.config.file-extension=properties # 配置要使用的nacos配置中心分组 spring.cloud.nacos.config.group=TEST_GROUP
- application.properties
# 激活使用profile spring.profiles.active=info
- application-info.properties
# nacos配置 server.port=3377
测试效果
3. 命名空间方案
新建命名空间
切换命名空间
- 修改配置文件bootstrap.properties实现切换
# 指定命名空间 dev #spring.cloud.nacos.config.namespace=401827ae-19b9-4fb4-a1fc-e55d57e6f6fe # 指定命名空间 test spring.cloud.nacos.config.namespace=5e79a451-9283-47cb-ac86-3bae58352240
添加分组和dataId(可以从default空间克隆)
参考上面的方案
测试结果
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。