接口调用失败的退避策略
2020-02-28 16:04:42来源:博客园 阅读 ()
接口调用失败的退避策略
退避策略简介
在开发过程中我们经常会遇到调用接口失败的情况。遇到这种情况,我们有时候需要重试机制,常用的重试(退避)策略有:
- 固定的时间间隔重试一次,最多重试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{
//在这里写你的重试逻辑
}
}
ExponentialBackOff
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
接口的实现。
参考
- https://www.iteye.com/blog/chenjumin-2437636
原文链接:https://www.cnblogs.com/54chensongxia/p/12376966.html
如有疑问请与原作者联系
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- Spring系列.ApplicationContext接口 2020-06-11
- 为什么阿里巴巴Java开发手册中强制要求接口返回值不允许使用 2020-06-06
- Java生鲜电商平台-生鲜电商接口幂等性原理与防重复提交方案( 2020-06-05
- Java连载120-反射机制获取构造方法和父类、父接口 2020-06-05
- Java Spring注入一个接口的多个实现类在map里如何实现?案 2020-06-04
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash