SpringCloud Alibaba Nacos注册中心和配置中心的使用及配置

SpringCloud Alibaba Nacos注册中心和配置中心的使用及配置

什么是Nacos?

Nacos 致力于帮助您发现、配置和管理微服务。Nacos 提供了一组简单易用的特性集,帮助您快速实现动态服务发现、服务配置、服务元数据及流量管理。
Nacos 帮助您更敏捷和容易地构建、交付和管理微服务平台。 Nacos 是构建以“服务”为中心的现代应用架构 (例如微服务范式、云原生范式) 的服务基础设施。

注册中心配置:(服务注册与发现)

官方文档:https://github.com/alibaba/spring-cloud-alibaba/blob/master/spring-cloud-alibaba-examples/nacos-example/nacos-discovery-example/readme.md

1、引入pom依赖:

 <dependency>
     <groupId>com.alibaba.cloud</groupId>
     <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
 </dependency>

2、下载Nacos-server-1.1.3 客户端

下载地址:
https://download.csdn.net/download/nxw_tsp/12720732

#官网下载地址
https://github.com/alibaba/nacos/releases/download/1.1.3/nacos-server-1.1.3.zip

3、启动Nacos客户端

下载好客户端之后进入bin目录,运行startup.cmd,然后打开链接:http://localhost:8848/nacos/ 进入注册中心管理页面

4、yml配置Nacos端口

# 注册中心配置
spring
  cloud:
    nacos:
      discovery:
        server-addr: 127.0.0.1:8848
  application:
    name: member  #在配置中心的名字

5、在启动类加注解:

//开启Nacos注册中心客户端
@EnableDiscoveryClient  

Nacos配置中心:

实现动态的修改配置文件效果。
官方文档:
https://github.com/alibaba/spring-cloud-alibaba/blob/master/spring-cloud-alibaba-examples/nacos-example/nacos-config-example/readme.md

1、导入依赖

<!-- Nacos配置中心来做配置管理 -->
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>

2、创建bootstrap.properties文件

spring.application.name=coupon
spring.cloud.nacos.config.server-addr=127.0.0.1:8848

3、在Nacos配置管理页面新增配置

在Nacos配置管理页面新增配置文件,文件名为该模块名字.properties。例如我的模块是coupon那文件名就为coupon.properties。

在配置文件里新增两个属性例如:

coupon.user.name = Silence
coupon.user.age = 20

4、动态获取配置

例如:我在couponController里获取了配置文件的内容,那么我在这个类头部添加 @RefreshScope 注解之后,通过Nacos修改coupon.properties就能获取到最新的数据。
在这里插入图片描述

@Value("${coupon.user.name}")
private String name;
@Value("${coupon.user.age}")
private Integer age;
@RequestMapping("/test")
public R testNacosConfig(){
    return R.ok().put("name",name).put("age",age);
}

配置中心properties和当前应用的其他配置文件优先级:
配置中心properties>其他配置文件

配置中心细节描述:

1、命名空间:环境隔离(dev,uat,prd)

默认的命名空间是public(保留空间);默认新增所有的配置都在public空间下。
我们可以在Nacos管理面板里面找到命名空间选项,新增命名空间,比如我们新增不同环境下的命名空间
在这里插入图片描述
新增完命名空间之后在对用的命名空间创建coupon.properties文件。

在这里插入图片描述
那么新增完之后我们还需要在 bootstrap.properties 配置文件里来配置我们到底需要调用哪个命名空间的文件。

#namespace为命名空间的ID
spring.cloud.nacos.config.namespace=c3ac50b1-cd7c-4df8-bf83-c011939b8771

同样的,如果我们的微服务比较多,我们也可以基于每个微服务来创建对应的命名空间来管理配置文件。

2、配置集

一组相关或者不相关的配置项的集合。在系统中,一个配置文件就是一个配置集。

3、配置集ID

就是Nacos中我们配置的Data Id(配置文件名)。

4、配置分组

默认所有的配置集都属于DEFAULT_GROUP
例如我们配置了不同的配置组,那么我们就需要在bootstrap.properties中来指定我们用的哪个配置组。

#my_group为你自己配置的组名
spring.cloud.nacos.config.group=my_group

同时加载多个配置集:

在实际开发中我们的配置文件是需要做很多的配置,那么多的配置都放到一个配置文件里进行管理是很容易混乱的,所以我们可以把这些配置分布到不同的配置文件进行配置。例如:和mybatis相关的配置我们放在mybatis.properties,和spring相关的配置我们放在spring.properties里。

第一步:在Nacos中新增配置文件

在这里插入图片描述

第二步:在配置文件中说明

配置文件创建好之后还需要在bootstrap.properties中说明需要加载的文件。

spring.cloud.nacos.config.ext-config[0].data-id=mybatis.yml
spring.cloud.nacos.config.ext-config[0].group=dev
spring.cloud.nacos.config.ext-config[0].refresh=true

spring.cloud.nacos.config.ext-config[1].data-id=spring.yml
spring.cloud.nacos.config.ext-config[1].group=dev
spring.cloud.nacos.config.ext-config[1].refresh=true

如果配置无误,我们在启动服务的时候会打印出来都加载了哪些配置文件。

  .   ____          _            __ _ _
 /\\ / ___'_ __ _ _(_)_ __  __ _ \ \ \ \
( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \
 \\/  ___)| |_)| | | | | || (_| |  ) ) ) )
  '  |____| .__|_| |_|_| |_\__, | / / / /
 =========|_|==============|___/=/_/_/_/
 :: Spring Boot ::        (v2.1.8.RELEASE)

2020-08-18 16:58:53.766  INFO 29532 --- [           main] c.a.c.n.c.NacosPropertySourceBuilder     : Loading nacos data, dataId: 'mybatis.yml', group: 'dev'
2020-08-18 16:58:53.779  INFO 29532 --- [           main] c.a.c.n.c.NacosPropertySourceBuilder     : Loading nacos data, dataId: 'spring.yml', group: 'dev'
2020-08-18 16:58:53.825  INFO 29532 --- [           main] c.a.c.n.c.NacosPropertySourceBuilder     : Loading nacos data, dataId: 'coupon.properties', group: 'dev'

Nacos的持久化操作:

关于Nacos的持久化操作还是比较简单的,我们也可以根据官方文档的步骤来进行操作:https://nacos.io/zh-cn/docs/deployment.html
根据Nacos官方的介绍,目前只支持Mysql来进行持久化。

1、首先我们需要在mysql数据库中新建一个数据库用于Nacos的数据存储,并且在库中新建Nacos所需的表(在Nacos的conf目录中,有nacos-mysql.sql文件,直接在mysql中运行便会生成所有需要的表)。
在这里插入图片描述
2、数据库以及表创建好之后,我们就要去Nacos的conf目录中的application.properties文件来配置数据库连接。

#*************** Config Module Related Configurations ***************#
### If use MySQL as datasource:
spring.datasource.platform=mysql

### Count of DB:
db.num=1

### Connect URL of DB:
db.url.0=jdbc:mysql://112.126.74.111:3306/nacos?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true&useUnicode=true&useSSL=false&serverTimezone=UTC
db.user=root
db.password=123456

3、重启Nacos
重启Nacos我们可以新建一个命名空间来测试一下是否被持久化在数据库中
在这里插入图片描述
在这里插入图片描述
在表tenant_info中我们可以看到刚刚新增的命名空间已经保存了。


版权声明:本文为nxw_tsp原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。