• 接口调用失败的退避策略


    退避策略简介

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

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

    Spring中的退避策略工具类

    FixedBackOff

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

    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接口的实现。

    参考

  • 相关阅读:
    Centos7.6安装教程 && history设置显示执行命令的时间
    C# 调用第三方webapi 接口的示例(使用httpclient)
    asp.net core 上传文件
    Sql中CHARINDEX用法---判断数据库某个字段是否包含某个字符
    ASP.NET上传文件出现“404-找不到文件或目录”的解决办法
    C# 中转换的几种方式
    C# 向文件写入和读取文件内容
    C# 中正则表达式
    C# 写的通用得到富文本框中的图片路径
    C# 正则表达式输入验证必须为汉字
  • 原文地址:https://www.cnblogs.com/54chensongxia/p/12376966.html
Copyright © 2020-2023  润新知