700字范文,内容丰富有趣,生活中的好帮手!
700字范文 > Nacos基本使用:注册中心 配置中心

Nacos基本使用:注册中心 配置中心

时间:2019-03-21 02:51:05

相关推荐

Nacos基本使用:注册中心 配置中心

导语

文章迁移:oldmoon.top文章注意:本文是建立在Nacos安装成功的基础上讲解。建议安装Nacos后,对照系统页面学习此文章。1、本文采取Nacos 2.0.3单例形式、服务单例形式来讲解,不涉及集群相关特定知识点。2、本文分为三部分来讲解Nacos的基本使用: 一、Nacos页面;二、Nacos作为注册中心使用;三、Nacos作为配置中心使用。 3、如有错误,请务必指出,感谢!

一、Nacos页面

主要讲解Nacos的一些通用性配置,如用户、角色配置等。

命名空间(namespace)

【重要】:Nacos所有配置的最顶层分组,项目中需要用到该字段值。默认的namespacepublic

命名空间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/propertiesfile-extension: yaml# 分组名称,默认为【DEFAULT_GROUP】group: CJBGD_PRO# 自动刷新配置,默认为truerefresh-enabled: true# 共享配置引用shared-configs:# 配置ID- data-id: shared-datasource-dbcp2-pro.yaml# 配置组名称,默认为【DEFAULT_GROUP】group: SHARED_PROrefresh: true- data-id: shared-redis-pro.yamlgroup: SHARED_PROrefresh: true- data-id: shared-info-pro.yamlgroup: SHARED_PROrefresh: true

上边我把我用到的所有配置全部贴出来了,注释也都写的很明白,不做太细的讲解,只说几个个人理解:config.name:应该填写配置中心中对应配置的data-id,可以缺省,缺省时默认使用本服务的spring.application.name的值。config.file-extension:配置文件拓展名,会自动和config.name组合,用.拼接为一个data-id到配置中心查找配置。config.shared-configs:声明引用哪些公共的配置。下边可以显式引用多个配置中心的配置文件。group:默认值为DEFAULT_GROUP,当配置文件较多时,建议自定义一些group,对配置文件进行分组管理,使用起来也更加清晰明了。

项目启动日志

-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-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-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-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-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-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都是显式的将各种信息填写到配置文件中了,所以没必要打印日志。

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。