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.命名空间和分组都要指定,不然也会报该错

相关推荐
维尔切15 分钟前
Linux中基于Centos7使用lamp架构搭建个人论坛(wordpress)
linux·运维·架构
知白守黑2671 小时前
lamp架构部署wordpress
架构
该用户已不存在1 小时前
OpenJDK、Temurin、GraalVM...到底该装哪个?
java·后端
TT哇2 小时前
@[TOC](计算机是如何⼯作的) JavaEE==网站开发
java·redis·java-ee
Tina学编程2 小时前
48Days-Day19 | ISBN号,kotori和迷宫,矩阵最长递增路径
java·算法
青川入梦2 小时前
MyBatis极速通关上篇:Spring Boot环境搭建+用户管理实战
java·开发语言·mybatis
执子手 吹散苍茫茫烟波3 小时前
leetcode415. 字符串相加
java·leetcode·字符串
小韩博3 小时前
网络安全(Java语言)脚本 汇总(二)
java·安全·web安全
萤丰信息3 小时前
技术赋能安全:智慧工地构建城市建设新防线
java·大数据·开发语言·人工智能·智慧城市·智慧工地
带刺的坐椅3 小时前
Java MCP 的鉴权?好简单的啦
java·鉴权·mcp·solon-ai