Dubbo + Nacos 服务启动报错,返回unknown user!
1、由于开启了nacos的安全认证,修改了nacos的application.properties
nacos.core.auth.enabled=true
2、错误信息如下:
Caused by: com.alibaba.nacos.api.exception.NacosException: Request nacos server failed:
at com.alibaba.nacos.client.naming.remote.gprc.NamingGrpcClientProxy.requestToServer(NamingGrpcClientProxy.java:279) ~[nacos-client-2.0.3.jar:na]
at com.alibaba.nacos.client.naming.remote.gprc.NamingGrpcClientProxy.doRegisterService(NamingGrpcClientProxy.java:129) ~[nacos-client-2.0.3.jar:na]
at com.alibaba.nacos.client.naming.remote.gprc.NamingGrpcClientProxy.registerService(NamingGrpcClientProxy.java:115) ~[nacos-client-2.0.3.jar:na]
at com.alibaba.nacos.client.naming.remote.NamingClientProxyDelegate.registerService(NamingClientProxyDelegate.java:95) ~[nacos-client-2.0.3.jar:na]
at com.alibaba.nacos.client.naming.NacosNamingService.registerInstance(NacosNamingService.java:145) ~[nacos-client-2.0.3.jar:na]
at org.apache.dubbo.registry.nacos.NacosNamingServiceWrapper.registerInstance(NacosNamingServiceWrapper.java:57) ~[dubbo-3.0.2.1.jar:3.0.2.1]
at org.apache.dubbo.registry.nacos.NacosRegistry.doRegister(NacosRegistry.java:170) ~[dubbo-3.0.2.1.jar:3.0.2.1]
... 42 common frames omitted
Caused by: com.alibaba.nacos.api.exception.NacosException: unknown user!
at com.alibaba.nacos.client.naming.remote.gprc.NamingGrpcClientProxy.requestToServer(NamingGrpcClientProxy.java:271) ~[nacos-client-2.0.3.jar:na]
... 48 common frames omitted
3、 pom.xml 依赖配置如下:
<properties>
<java.version>1.8</java.version>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<spring-boot.version>2.3.6.RELEASE</spring-boot.version>
<dubbo.version>3.0.2.1</dubbo.version>
<nacos.version>2.0.3</nacos.version>
</properties>
<dependencyManagement>
<dependencies>
<!-- spring boot 2.3.2.RELEASE -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<version>${spring-boot.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<dependencies>
<!-- spring boot 集成 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!-- dubbo spring boot 集成 -->
<dependency>
<groupId>org.apache.dubbo</groupId>
<artifactId>dubbo-spring-boot-starter</artifactId>
<version>${dubbo.version}</version>
</dependency>
<!-- dubbo nacos 集成 -->
<dependency>
<groupId>org.apache.dubbo</groupId>
<artifactId>dubbo-registry-nacos</artifactId>
<version>${dubbo.version}</version>
</dependency>
<dependency>
<groupId>com.alibaba.nacos</groupId>
<artifactId>nacos-client</artifactId>
<version>${nacos.version}</version>
</dependency>
</dependencies>
4、application.yml 配置内容如下:
spring:
application:
name: dubbo-demo-provider
jackson:
time-zone: GMT+8
date-format: yyyy-MM-dd HH:mm:ss
dubbo:
application:
name: dubbo-demo-provider
# 禁用QOS同一台机器可能会有端口冲突现象
qos-enable: false
qos-accept-foreign-ip: false
scan:
# 配置接口扫描包
base-packages: tm.ucp.service
protocol:
# 协议类型
name: dubbo
port: 8888
registry:
protocol: dubbo
address: nacos://localhost:8848?username=${username}&password=${password}
timeout: 3000
# 默认【public】 配置 namespace
parameters:
namespace: eec62008-6264-4e6e-aee8-bebb1c26a8ab
解决方法:
由于dubbo的源码中发现 username、paasword并没有实际用到,
而在 RegistryConfig 类中发现 address属性值中,对username、password值进行了处理
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-GJXXZjXc-1723557960666)(https://i-blog.csdnimg.cn/blog_migrate/f07e126711b0b463804016cbb397f224.png)]
故采用如下方法进行配置
dubbo:
registry:
address: nacos://localhost:8848?username=${username}&password=${password}
https://github.com/apache/dubbo/issues/5956
至此已成功解决,写的不好,望各位指正!!!