feign 【已解决】报错 org.springframework.cloud.netflix.ribbon.RibbonLoadBalancerClient.choose
org.springframework.cloud.netflix.ribbon.RibbonLoadBalancerClient.choose(Ljava/lang/String;Lorg/springframework/cloud/client/loadbalancer/Request;)Lorg/springframework/cloud/client/ServiceInstance;
org.springframework.cloud.netflix.ribbon.RibbonLoadBalancerClient.choose(Ljava/lang/String;Lorg/springframework/cloud/client/loadbalancer/Request;)Lorg/springframework/cloud/client/ServiceInstance;
报错原因 2.x\3.x的spring cloud自带 ribbon
主要原因是还是jar包冲突,nacos依赖的ribbon和springcloud的ribbon存在同个方法的不同实现,不兼容。
排除掉nacos的spring-cloud-starter-netflix-ribbon依赖:
本质上是jar包冲突,nacosnacos依赖的ribbon和springcloud的ribbon存在同个方法的不同实现,导致了不兼容。
解决方法:
1.在库中将ribbon删掉nacos的ribbon jar包
删掉这两个
Maven: org.springframework.cloud:spring-cloud-netflix-ribbon:2.2.10.RELEASE
Maven: org.springframework.cloud; spring-cloud-starter-netflix-ribbon:2.2.10.RELEASE
2.在pom中排除掉依赖
<!-- nacos discovery starter -->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
<exclusions>
<exclusion>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflex-ribbon</artifactId>
</exclusion>
<exclusion>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-netflex-ribbon</artifactId>
</exclusion>
</exclusions>
</dependency>
又被一个错误浪费了半天时间,最开始全局异常处理类没关,导致 feign远程调用方法出错但没有报错日志,来来回回排查了好几遍代码,才想起来关掉全局异常处理。必要的时候还是要相信自己的代码没有错,去找其他的问题,要不然就是在白白浪费时间了。
更多推荐
所有评论(0)