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远程调用方法出错但没有报错日志,来来回回排查了好几遍代码,才想起来关掉全局异常处理。必要的时候还是要相信自己的代码没有错,去找其他的问题,要不然就是在白白浪费时间了。

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐