在开发过程中我们经常会遇到调用接口失败的情况。遇到这种情况,我们有时候需要重试机制,常用的重试(退避)策略有:
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{
//在这里写你的重试逻辑
}
}
ExponentialBackOff是支持尝试间隔呈指数增加的工具类,使用方式和上面类似:
long initialInterval = 100; //初始间隔
double multiplier = 2.0; //递增倍数
long maxInterval = 5 * 1000L; //最大间隔
long maxElapsedTime = 50 * 1000L; //累计最大的时间间隔
ExponentialBackOff backOff = new ExponentialBackOff(initialInterval, multiplier);
backOff.setMaxInterval(maxInterval);
backOff.setMaxElapsedTime(maxElapsedTime);
BackOffExecution execution = backOff.start();
while(true){
long value = execution.nextBackOff();
if(value == BackOffExecution.STOP){
break;
}else{
//在这里写你的重试逻辑
}
}
如果你想要实现自己的退避策略,也非常简单。参考上面两个类中对于BackOffExecution接口的实现。