前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >接口调用失败的退避策略

接口调用失败的退避策略

作者头像
崔笑颜
发布2020-06-08 16:56:01
2.8K0
发布2020-06-08 16:56:01
举报
文章被收录于专栏:小小码农一个。

退避策略简介

在开发过程中我们经常会遇到调用接口失败的情况。遇到这种情况,我们有时候需要重试机制,常用的重试(退避)策略有:

  1. 固定的时间间隔重试一次,最多重试N次:比如我现在一个接口调用失败了,不是立马返回失败,而是hold住线程,每隔2秒重新调下接口,最多调5次,只要其中一次成功了就直接返回。如果5次都没成功,接口返回失败。
  2. 指数时间间隔尝试策略:和上面策略一样,接口调用失败后也不是直接返回,但是重试的时间间隔呈指数增加。比如第一次时间间隔是2s,第二次次4s,依次增加。当然你也可以设置最大的尝试次数和最大的尝试时间。

Spring中的退避策略工具类

FixedBackOff

FixedBackOff是Spring自带的支持固定时间退避策略的工具类。这个类使用起来非常简单:

代码语言:javascript
复制
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

ExponentialBackOff是支持尝试间隔呈指数增加的工具类,使用方式和上面类似:

代码语言:javascript
复制
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接口的实现。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-02-28,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 退避策略简介
    • Spring中的退避策略工具类
      • FixedBackOff
      • ExponentialBackOff
      • 自定义退避策略
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档