
接口调用失败的退避策略
发布日期:2021-05-08 23:11:27
浏览次数:14
分类:博客文章
本文共 1326 字,大约阅读时间需要 4 分钟。
退避策略简介
在开发过程中我们经常会遇到调用接口失败的情况。遇到这种情况,我们有时候需要重试机制,常用的重试(退避)策略有:
- 固定的时间间隔重试一次,最多重试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
接口的实现。
参考
发表评论
最新留言
很好
[***.229.124.182]2025年03月30日 13时51分32秒
关于作者

喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
Git学习笔记
2021-05-09
SpringBoot笔记
2021-05-09
让你的代码更优秀的 14 条建议
2021-05-09
不需要爬虫也能轻松获取 unsplash 上的图片
2021-05-09
将博客搬至CSDN
2021-05-09
elementUi源码解析(1)--项目结构篇
2021-05-09
自动遍历测试之Monkey工具
2021-05-09
Nmap扫描工具介绍
2021-05-09
算法笔记:递归、动态规划
2021-05-09
Pytest插件开发
2021-05-09
常用Windows 快捷键
2021-05-09
linux命令-压缩与打包
2021-05-09
ORACLE 11g 生产中高水位线(HWM)处理
2021-05-09
centos 6.x 编译安装 pgsql 9.6
2021-05-09
weblogic 服务器部署SSL证书
2021-05-09