这里将告诉您接口调用失败的退避策略,具体实现方法:退避策略简介
在开发过程中我们经常会遇到调用接口失败的情况。遇到这种情况,我们有时候需要重试机制,常用的重试(退避)策略有:
固定的时间间隔重试一次,最多重试N次:比如我现在一个接口调用失败了,不是立马返回失败,而是hold住线程,每隔2秒重新调下接口,最多调5次,只要其中一次成功了就直接返回。如果5次都没成功,接口返回失败。
指数时间间隔尝试策略:和上面策略一样,接口调用失败后也不是直接返回,但是重试的时间间隔呈指数增加。比如第一次时间间隔是2s,第二次次4s,依次增加。当然你也可以设置最大的尝试次数和最大的尝试时间。
Spring中的退避策略工具类
FixedBackOff
FixedBackOff是Spring自带的支持固定时间退避策略的工具类。这个类使用起来非常简单:
long interval = 1000; //重试间隔 1s重试一次
long maxAttempts = 10; //最大重试次数 最多重试10次
BackOff backOff = new FixedBackOff(interval, maxAttempts);
BackOffExecution execution = backOff.start();
while(true){
long value = execution.nextBackOff();
if(value == BackOffExecution.STOP){
break;
}else{