在做微服务开发中,测试环境使用Nacos没有问题,但是生产环境服务启动一直报错:
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.doSubscribe(NamingGrpcClientProxy.java:227) ~[nacos-client-2.0.3.jar:na]
at com.alibaba.nacos.client.naming.remote.gprc.NamingGrpcClientProxy.subscribe(NamingGrpcClientProxy.java:212) ~[nacos-client-2.0.3.jar:na]
at com.alibaba.nacos.client.naming.remote.NamingClientProxyDelegate.subscribe(NamingClientProxyDelegate.java:147) ~[nacos-client-2.0.3.jar:na]
at com.alibaba.nacos.client.naming.NacosNamingService.subscribe(NacosNamingService.java:393) ~[nacos-client-2.0.3.jar:na]
原因分析 版本不一致
代码没有改动,测试环境没问题,但是生产环境有问题呢?首先看一下两者不同的地方,大多数都是环境配置的问题。
查看Nacos
服务的版本,查看Nacos
控制台首页左上角就能看到版本号:
测试环境版本是2.0.x.RELEASE
,生产环境版本是2.1.x.RELEASE
,再看alibaba.cloud
中的maven
中的依赖:
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-dependencies</artifactId>
<version>2.0.1.RELEASE</version>
<type>pom</type>
<scope>import</scope>
</dependency>
解决方案
将依赖从2.0.x.RELEASE
改成2.1.x.RELEASE
。
Nacos
服务端maven
依赖对应的版本号保持一致。Spring Boot
依赖的版本号也要保持一致。版本 2.1.x.RELEASE
对应的是Spring Boot 2.1.x
版本。版本2.0.x.RELEASE
对应的是Spring Boot 2.0.x
版本,具体查看官方详解。
总结
-
Nacos
服务端和Nacos
依赖的版本号要一致 -
Spring Boot
和Spring Cloud Alibaba
版本号要保持一致,Spring Cloud
也需要对应匹配。具体查看https://github.com/alibaba/spring-cloud-alibaba/wiki/版本说明
。
原文始发于微信公众号(小码Code):Nacos 版本不一致报错: Request nacos server failed
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/72272.html