vlambda博客
学习文章列表

Nacos统一配置中心

1、简介

nacos管理配置文件方式是在自己所在的服务器上形成一个版本库,因此不需要再创建远程版本库。Nacos作为统一配置中心管理配置文件时,同样也是存在版本控制。

2、开发微服务作为统一配置中心客户端将配置交给nacos进行管理

2.1 创建项目并引入nacos配置中心依赖

  <!--引入nacos client 依赖-->
         <dependency>
             <groupId>com.alibaba.cloud</groupId>
             <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
         </dependency>
         <!--引入配置中心依赖-->
         <dependency>
             <groupId>com.alibaba.cloud</groupId>
             <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
         </dependency>
 

2.2 配置配置中心地址

文件名必须为bootstrap.properties

 # 告诉config server地址
 spring.cloud.nacos.config.server-addr=192.168.159.22:8848
 
 #从哪个命名空间获取配置(命名空间ID)
 spring.cloud.nacos.config.namespace=781c1432-8a70-413f-aaa8-559cac6057ed
 
 #告诉从哪个组进行配置获取
 spring.cloud.nacos.config.group=DEFAULT_GROUP
 #从这个组中拉取哪个配置文件
 spring.cloud.nacos.config.name=configclient-prod
 #指定读取文件后缀
 spring.cloud.nacos.config.file-extension=properties

Nacos统一配置中心

2.3 在Nacos中创建配置

Nacos统一配置中心

Nacos统一配置中心记住custom.username这个值,我们在后面会用到,先不用管上面的public|EMS|dangdang三个命名空间。

2.4 编写控制器测试配置读取情况

 
 @RestController
 @RefreshScope   //允许远端配置修改自动刷新
 @Slf4j
 public class DemoController {
 
     @Value("${custom.username}")
     private String username;
 
     @GetMapping("/demo")
     public String demo(){
         log.info("demo ok!!!");
         return "demo ok !!! username:"+username;
    }
 }

Nacos统一配置中心

2.5 启动项目并测试

Nacos统一配置中心Nacos统一配置中心

可以看到,配置拉取成功了。

2.6 实现自动配置刷新(比consul+config+Spring Cloud Bus那个简单多了)

默认情况下nacos已经实现了自动配置刷新功能,如果需要刷新配置直接在控制器中加入@@RefreshScope注解即可。Nacos统一配置中心我们现在nacos上修改配置Nacos统一配置中心点击发布:Nacos统一配置中心测试,可以看到配置已经自动刷新了,真的比config+consul+bus那个简单多了,阿里云好牛逼。Nacos统一配置中心

3 nacos配置中心细节

3.1 DataId

用来读取远程配置中心的中具体配置文件其完整格式如下:

 ${prefix}-${spring.profile.active}.${file-extension}
  • prefix 默认为 spring.application.name 的值,也可以通过配置项 spring.cloud.nacos.config.prefix来配置。

  • spring.profile.active 即为当前环境对应的 profile,详情可以参考 Spring Boot文档。注意:当 spring.profile.active 为空时,对应的连接符 - 也将不存在,dataId 的拼接格式变成 ${prefix}.${file-extension}

  • file-exetension 为配置内容的数据格式,可以通过配置项 spring.cloud.nacos.config.file-extension 来配置。目前只支持 properties 和 yaml 类型。

3.2 微服务拉取配置的两种方式

3.2.1  第一种(dataId=name+file-extension)

 # 告诉config server地址
 spring.cloud.nacos.config.server-addr=192.168.159.22:8848
 
 #从哪个命名空间获取配置(命名空间ID)
 spring.cloud.nacos.config.namespace=781c1432-8a70-413f-aaa8-559cac6057ed
 
 #告诉从哪个组进行配置获取
 #spring.cloud.nacos.config.group=DEFAULT_GROUP
 spring.cloud.nacos.config.group=CONFIGCLIENT
 
 
 #第一种配置文件获取方式 dataId=name+file-extension
 #从这个组中拉取哪个配置文件
 spring.cloud.nacos.config.name=configclient-prod
 #指定读取文件后缀
 spring.cloud.nacos.config.file-extension=properties

3.2.2 第二种(dataId=prefix+env+file-extension)

 # 告诉config server地址
 spring.cloud.nacos.config.server-addr=192.168.159.22:8848
 
 #从哪个命名空间获取配置(命名空间ID)
 spring.cloud.nacos.config.namespace=781c1432-8a70-413f-aaa8-559cac6057ed
 
 #告诉从哪个组进行配置获取
 #spring.cloud.nacos.config.group=DEFAULT_GROUP
 spring.cloud.nacos.config.group=CONFIGCLIENT
 
 
 #第二种配置文件获取方式 dataId=prefix+env+file-extension
 spring.cloud.nacos.config.prefix=configclient
 spring.profiles.active=prod
 spring.cloud.nacos.config.file-extension=properties

3.3 统一配置中心nacos三个重要概念

3.3.1 命名空间:namespace

<font size="4"> 默认nacos安装完成之后会有一个默认的命名空间,这个命名空间的名字为public。作用:站在项目总角度隔离每一个项目配置文件。

3.3.2 组:group

<font size="4">默认nacos中在管理配置文件时不显示指定group名称则默认的组名称为DEFAULT_GROUP作用:站在项目中每个服务角度,隔离同一个项目中不同服务的配置

3.3.3 文件名:dataId

<font size="4">获取一个配置文件的唯一标识。