八、Ribbon 负载均衡的坑

由于Feign一般使用更加方便,所以这个问题是在Feign调用多个服务的时候出现了404.

描述:案例中 是 服务A 调用了服务B,然后调用了服务C,再次调用B的时候出现了404. 控制台输出如下异常:

1
2
3
4
5
feign.FeignException: status 404 reading FeignService#echo(String)
at feign.FeignException.errorStatus(FeignException.java:78) ~[feign-core-10.1.0.jar:na]
at feign.codec.ErrorDecoder$Default.decode(ErrorDecoder.java:93) ~[feign-core-10.1.0.jar:na]
at feign.SynchronousMethodHandler.executeAndDecode(SynchronousMethodHandler.java:149) ~[feign-core-10.1.0.jar:na]
at feign.SynchronousMethodHandler.invoke(SynchronousMethodHandler.java:78) ~[feign-core-10.1.0.jar:na]

其实异常是由于Ribbon引起的,由于Feign中封装使用了Ribbon,所以虽然是在使用Feign,但是是由于Ribbon造成的,我们来看看如何解决:

这个问题是由于Ribbon配置扫描的问题导致的:我们到官网看一下:

https://cloud.spring.io/spring-cloud-static/spring-cloud-netflix/2.2.0.M3/reference/html/#customizing-the-ribbon-client

我们看一下警告的地方:自定义的配置类(CustomConfiguration)必须是一个被@configuration 注解标识的类,并且不应该被@ComponentScan 扫描到。当然也不能被@component@SpringBootApplication 注解扫描到,如果扫描到会被所有的RibbonClient共享。

解决方法

配置文件:

1
2
3
4
5
6
7
8
9
@Configuration
public class LoadBalanceConfig {

@Bean
public IRule iRule(){
// return new RandomRule();//随机策略
return new RoundRobinRule();//轮询策略
}
}
#

评论

Your browser is out-of-date!

Update your browser to view this website correctly. Update my browser now

×