java调用接口失败重调_java接口调用失败的退避策略

本文介绍了在Java开发中遇到接口调用失败时如何采用重试策略,包括固定时间间隔和指数时间间隔的退避策略,并展示了Spring中FixedBackOff和ExponentialBackOff的使用示例。
摘要由CSDN通过智能技术生成

201610181557196870.jpg

码农公社  210.net.cn  210= 1024  10月24日一个重要的节日--码农(程序员)节

退避策略简介

在开发过程中我们经常会遇到调用接口失败的情况。遇到这种情况,我们有时候需要重试机制,常用的重试(退避)策略有:固定的时间间隔重试一次,最多重试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 =

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值