导语
- 注意:本文是建立在Nacos安装成功的基础上讲解。建议安装Nacos后,对照系统页面学习此文章。
- 1、本文采取
Nacos 2.0.3
单例形式、服务单例形式来讲解,不涉及集群相关特定知识点。 - 2、本文分为三部分来讲解Nacos的基本使用:
- 一、Nacos页面;
- 二、Nacos作为注册中心使用;
- 三、Nacos作为配置中心使用。
- 3、如有错误,请务必指出,感谢!
一、Nacos页面
- 主要讲解Nacos的一些通用性配置,如用户、角色配置等。
命名空间(namespace)
- 【重要】:Nacos所有配置的最顶层分组,项目中需要用到该字段值。
- 默认的
namespace
是public
。 - 命名空间ID:可以不填,会自动生成一个不规则值,也可以自定义,不能重复。
- 命名空间名:自定义一个名称,帮助识别分组。
- 描述:字面意思
新增后检查
- 命名空间新增后,随便点点页面,你会在很多地方可以找到该分组,如上图【配置管理】–【配置列表】中。
Nacos用户相关配置
创建用户
- 上图为Nacos系统页面,启动Nacos成功后,访问Nacos页面,默认的登录用户账号密码都是
nacos
。 - 进入页面后,找到【权限控制】–【用户列表】,在该页面可以创建用户,只需要输入账号和密码即可创建。
创建角色
- 如图进入【权限控制】–【角色管理】,点击绑定角色弹出图中窗口,可以自定义一个新的角色名,也可以填已经存在的角色名,用户名必须是已存在的用户。
- 注意:之所以说
可以自定义一个新的角色名,也可以填已经存在的角色名
的,因为这里即可以视为角色和用户的关系维护,也可以视为新增角色。 - 一般我们对角色、用户的理解可能是:先有用户和角色,再给用户指定相应的角色。但是在这里不太一样,可以理解为角色创建时,即绑定了用户:必须先有用户,创建角色时,必须指定一个已存在的用户。
权限管理
- 如图进入【权限控制】–【权限管理】,即角色权限的维护页面。
- 角色名:已存在的一个角色名
- 资源:命名空间(namespace)
- 动作:只读、只写、读写
二、Nacos作为注册中心使用
创建项目
- 创建一个普通的SpringCloud项目,引入如下Nacos的maven依赖:
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
- 项目中创建
bootstrap.yml
配置文件,添加如下Yml配置:
spring:
cloud:
nacos:
# 【注册中心】相关配置
discovery:
# 命名空间(大分组)
namespace: cjbgd_nacos
# 分组名称,默认为【DEFAULT_GROUP】
group: CJBGD_DEV
# 注册中心地址
server-addr: localhost:8848
- 启动类上增加注解:
@EnableDiscoveryClient
启动项目
- 项目启动成功后,可以到Nacos页面中看到如下图的结果
三、Nacos作为配置中心使用
- nacos作为配置中心,主要分两部分:1、配置管理;2、配置引用。
- 配置管理:使用Nacos页面管理配置文件。
- 配置引用:在项目中引用想要的配置。
配置管理
新增配置文件
- Nacos作为配置中心,必须先在Nacos管理页面新增一些配置。
- 在【配置管理】–【配置列表】页面中,点击右侧加号,进入配置新增页面
- 在新增页面中填写相应信息。
- Data ID:配置文件名。【如果在引用时,想要某个项目缺省式的引用到该配置文件,
Data ID
应该与服务的spring.application.name
保持一致】 - Group:配置分组,默认为
DEFAULT_GROUP
- 描述:描述
- 配置格式:按需选择,现在一般都用
yaml
,即yml
- 配置内容:配置内容
- 填写示例
注意
- Nacos配置新增保存成功后,新增页面不会自动关闭,只会弹出成功提示框。即这个新增页面不会主动关闭,而且不会清空已填写的内容,会一直开着,直到你手动返回。
- 如果你以为你新增失败了,再次点击保存,会弹出已存在同名配置的错误提示。
- 且新增页面只能用来新增配置,新增后想要修改必须返回列表,点击对应配置后边的【编辑】按钮。
- 这是个使用习惯的问题,对我来说刚使用的时候不是很友好,用多了也就无所谓了。
配置导出
- 在微服务时代,微服务越多吗,配置文件也就越多,在开发环境、正式环境中,总不能每次改动都是都在Nacos的编辑页面修改配置吧,所以配置导入导出就很有必要。
- 如上图,主要就是两种选择:
- 导出查询结果:根据查询条件,把查出的所有配置一起导出。
- 导出选中的配置:导出选中的配置。
- 至于有个【新版】,我猜测是分页数据导出的优化?由于我的配置文件较少,没有做测试,有想法的可以试试。
- 导出的是一个zip压缩包,打开可以看到导出文件如下图:
配置导入
- 细心地同学看导出文件时候,会发现没有导出命名空间(namespace)的信息,这也意味着,导出的配置可以导入到任意的命名空间中,导入前点到想要导入的命名空间即可。
- 如下图,先进入
cjbgd_nacos
的命名空间中,再点击【导入配置
】,弹出的窗口会自动显示导入的空间信息,且不能更改。 - 上传的文件,直接选中导出的压缩包即可。
配置引用
引用配置
- 项目中想用配置中心,还要写相应配置,告诉项目我要用哪个配置中心、哪个配置文件。【没有希洛克打啥希洛克!?没有奥兹玛打啥奥兹玛!?突然感觉有点道理。。。】
- 配置示例:
spring:
cloud:
nacos:
# 【配置中心】相关配置
config:
# 命名空间(大分组)
namespace: cjbgd_nacos
# 配置中心地址
server-addr: 127.0.0.1:8848
# 配置文件的data-id,默认使用服务名(spring.application.name)
#name: gateway.yaml
# 配置文件类型:test/json/xml/yaml/properties
file-extension: yaml
# 分组名称,默认为【DEFAULT_GROUP】
group: CJBGD_PRO
# 自动刷新配置,默认为true
refresh-enabled: true
# 共享配置引用
shared-configs:
# 配置ID
- data-id: shared-datasource-dbcp2-pro.yaml
# 配置组名称,默认为【DEFAULT_GROUP】
group: SHARED_PRO
refresh: true
- data-id: shared-redis-pro.yaml
group: SHARED_PRO
refresh: true
- data-id: shared-info-pro.yaml
group: SHARED_PRO
refresh: true
- 上边我把我用到的所有配置全部贴出来了,注释也都写的很明白,不做太细的讲解,只说几个个人理解:
-
config.name
:应该填写配置中心中对应配置的data-id
,可以缺省,缺省时默认使用本服务的spring.application.name
的值。 -
config.file-extension
:配置文件拓展名,会自动和config.name
组合,用.
拼接为一个data-id
到配置中心查找配置。 -
config.shared-configs
:声明引用哪些公共的配置。下边可以显式引用多个配置中心的配置文件。 -
group
:默认值为DEFAULT_GROUP
,当配置文件较多时,建议自定义一些group
,对配置文件进行分组管理,使用起来也更加清晰明了。
项目启动日志
2022-04-12 11:54:14.224 INFO 65808 --- [ main] c.a.n.client.config.impl.ClientWorker : [fixed-localhost_8848-cjbgd_nacos] [subscribe] gateway+CJBGD_DEV+cjbgd_nacos
2022-04-12 11:54:14.224 INFO 65808 --- [ main] c.a.nacos.client.config.impl.CacheData : [fixed-localhost_8848-cjbgd_nacos] [add-listener] ok, tenant=cjbgd_nacos, dataId=gateway, group=CJBGD_DEV, cnt=1
2022-04-12 11:54:14.225 INFO 65808 --- [ main] c.a.n.client.config.impl.ClientWorker : [fixed-localhost_8848-cjbgd_nacos] [subscribe] gateway.yaml+CJBGD_DEV+cjbgd_nacos
2022-04-12 11:54:14.225 INFO 65808 --- [ main] c.a.nacos.client.config.impl.CacheData : [fixed-localhost_8848-cjbgd_nacos] [add-listener] ok, tenant=cjbgd_nacos, dataId=gateway.yaml, group=CJBGD_DEV, cnt=1
2022-04-12 11:54:14.225 INFO 65808 --- [ main] c.a.n.client.config.impl.ClientWorker : [fixed-localhost_8848-cjbgd_nacos] [subscribe] gateway-dev.yaml+CJBGD_DEV+cjbgd_nacos
2022-04-12 11:54:14.225 INFO 65808 --- [ main] c.a.nacos.client.config.impl.CacheData : [fixed-localhost_8848-cjbgd_nacos] [add-listener] ok, tenant=cjbgd_nacos, dataId=gateway-dev.yaml, group=CJBGD_DEV, cnt=1
- debug模式启动项目,观察启动日志会发现上面的日志,可以看到他在从配置中心加载哪些配置。
- 但是没有发现
shared-configs
引用的相关日志,可能开发者任务缺省的形式才有必要打印日志,而shared-configs
都是显式的将各种信息填写到配置文件中了,所以没必要打印日志。