nacos升级开启鉴权后,微服务无法连接的解决方案

版本:

|----------------------|---------------|----------------------------|
| 软件 | 版本号 | 备注 |
| spring boot | 2.2.5.RELEASE | |
| spring-cloud | Hoxton.SR3 | |
| spring-cloud-alibaba | 2.2.1.RELEASE | |
| nacos | 2.0.1 | 从1.4.2版本进行升级。同时作为注册中心和配置中心 |

一、升级nacos版本,开启鉴权

1.在application.properties配置文件开启鉴权,保存后重启nacos

复制代码
nacos.core.auth.enabled=true

2.登录nacos,"权限控制"->"用户列表"->"创建用户",例如test

3."权限控制"->"角色管理"->"绑定角色",例如将test用户绑定test_role角色

4."权限控制"->"权限管理"->"添加权限",例如为test_role角色添加xxxx命名空间的资源和读写权限。

二、代码调整

在微服务的bootstrap.properties配置文件中补充:

复制代码
#nacos服务地址
spring.cloud.nacos.config.server-addr=127.0.0.1:8848
#nacos鉴权账户
spring.cloud.nacos.config.username=test
spring.cloud.nacos.config.password=123123
#对应的命名空间ID
spring.cloud.nacos.config.namespace=7104456b-d77d-43a0-a8db-d8daf6a85cbe
#分组,标记环境
spring.cloud.nacos.config.group=SENTINEL_GROUP

三、在nacos的配置文件中调整对应服务的配置文件中补充:

复制代码
spring.cloud.nacos.discovery.server-addr=127.0.0.1:8848
spring.cloud.nacos.discovery.username=test
spring.cloud.nacos.discovery.password=123123
spring.cloud.nacos.discovery.namespace=7104456b-d77d-43a0-a8db-d8daf6a85cbe
spring.cloud.nacos.discovery.group=SENTINEL_GROUP

四、重启微服务,启动成功。

常见问题

NacosPropertySourceBuilder : get data from Nacos error

NacosException:There was an unexpected error (type=Forbidden, status=403). unknown user!

1.经检查发现是配置鉴权账户时,用的是name,没有使用username,导致覆盖了

复制代码
spring.application.name的dataId配置,并且也没有指定鉴权账户。

2.命名空间和分组都要指定,不然也会报该错

相关推荐
掘金-我是哪吒8 分钟前
分布式微服务系统架构第158集:JavaPlus技术文档平台日更-JVM基础知识
jvm·分布式·微服务·架构·系统架构
程序无bug14 分钟前
手写Spring框架
java·后端
程序无bug16 分钟前
Spring 面向切面编程AOP 详细讲解
java·前端
JohnYan16 分钟前
模板+数据的文档生成技术方案设计和实现
javascript·后端·架构
全干engineer28 分钟前
Spring Boot 实现主表+明细表 Excel 导出(EasyPOI 实战)
java·spring boot·后端·excel·easypoi·excel导出
Da_秀31 分钟前
软件工程中耦合度
开发语言·后端·架构·软件工程
Fireworkitte37 分钟前
Java 中导出包含多个 Sheet 的 Excel 文件
java·开发语言·excel
GodKeyNet1 小时前
设计模式-责任链模式
java·设计模式·责任链模式
a_Dragon11 小时前
Spring Boot多环境开发-Profiles
java·spring boot·后端·intellij-idea
泽02021 小时前
C++之红黑树认识与实现
java·c++·rpc