目录

Nacos

Nacos /nɑ:kəʊs/ 是 Dynamic Naming and Configuration Service 的首字母简称,一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。

依赖的数据分层

依赖的数据为配置文件,应用数据,环境变量等,无论形态如何,大体可分为如下几类。

  • 节点信息 :IP与端口、用户与密码对、域名与库、表、队列名、文件路径与环境变量等
  • 负载信息 : 灰度策略、分级服务、日志级别、线程数、内存数等
  • 业务信息 : 参数格式、存在性、版本与检查性数据常量等
  • 会话信息 : 初始不存在,程序包运行后存取的信息,会影响下次的运行路径
  • 除了会话信息之外,我们可以使用nacos统一配置。按照这里的分层可以让运维、测试、开发工程师协作各自负责其所应该承担的部分职能。

Spring Cloud Alibaba Nacos Config 目前提供了三种配置能力从 Nacos 拉取相关的配置。

  • 通过 spring.cloud.nacos.config.shared-configs[n].data-id 支持多个共享 Data Id 的配置
  • 通过 spring.cloud.nacos.config.extension-configs[n].data-id 的方式支持多个扩展 Data Id 的配置
  • 通过内部相关规则(应用名、应用名+ Profile )自动生成相关的 Data Id 配置 当三种方式共同使用时,他们的一个优先级关系是:A < B < C

环境隔离

就像Maven用groupId、artifactId、version三者来定位jar包在仓库中的位置一样,Nacos也提供了 Namespace (命名空间) 、Data ID (配置集ID)、 Group (组) 来确定一个配置文件(或者叫配置集)。

由此,实现多环境配置的方案也有三种:

  • 用命名空间(namespace)来区分不同的环境,一个命名空间对应一个环境;
  • 用配置组(group)来区分不同的环境,命名空间用默认的public即可,一个组对应一种环境;
  • 用配置集ID(Data ID)名称来区分不同的环境,命名空间和组用默认的即可,通过文件命名来区分;

命名空间用默认的 public。默认 group 为 DEFUALT_GROUP

利用 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}.${file-extension}
  • file-exetension 为配置内容的数据格式,可以通过配置项 spring.cloud.nacos.config.file-extension 来配置。目前只支持 properties 和 yaml/yml 类型。

利用 Group 来区分环境

1
java -Dspring.cloud.nacos.config.group=DEV_GROUP -jar demo-1.0.jar

利用 Namespace 区分环境

创建命名空间的时候,如果不指定ID,则自动生成的id就是这样的uuid字符串,还是自己指定一个有意义的ID。

1
java -Dspring.cloud.nacos.config.namespace=dev -jar demo-1.0.jar

最好的是用Namespace区分环境,清晰明了,而且有利于做权限控制

附录