问题:
最近刚开始使用openfeign,发现一次get请求,在请求的失败的时候,消费者会收到两次的请求。但是发送端明明只发送了一次请求。根据报错的代码定位不太容易定位到源码重试的位置。之前一直错误的把问题原因归结到了是重试的配置出现错误,在配置文件,代码的配置,拦截器等多个问题点进行了找原因,最后都没有解决。最不可思议的是,我关掉了系统中的重试,但是这个重试的场景依旧在。后来终于在网上看到了 参考中的帖子,定位到了源码中重试的原因。
总结:
请求失败的情况下,如果不是get请求,只能请求一次。
而get请求再失败的重试判断条件中,请求方法等于get也会返回true才会重复尝试。
post请求 就不会调用两次。
源码类名:RibbonLoadBalancedRetryPolicy
判断是否重试的方法代码:
public boolean canRetry(LoadBalancedRetryContext context) {
HttpMethod method = context.getRequest().getMethod();
// 重试的条件之一,如果是get 或者是 允许请求的配置则返回 true,允许重试。
// 调用方法的上级有数量的限制,也就是说不会有get的请求一直重复下去的
return HttpMethod.GET == method || lbContext.isOkToRetryOnAllOperations();
}
@Override
public boolean canRetryNextServer(LoadBalancedRetryContext context) {
// this will be called after a failure occurs and we increment the counter
// so we check that the count is less than or equals to too make sure
// we try the next server the right number of times
// 这步操作有数量作为校验的条件 再补充上 canRetry的校验
return nextServerCount <= lbContext.getRetryHandler().getMaxRetriesOnNextServer()
&& canRetry(context);
}
// 参考
链接:https://www.jianshu.com/p/37425555ccf8