Sprong Boot学习|使用 guava-retrying 实现重试

背景

后端业务系统可能会在接口调用失败、网络拥塞超时、任务执行失败、系统错误等异常情况出现的时候进行重试操作,然而不同的场景对于重试的延迟间隔,频次等会有不同的要求,如果自己编排重试代码会比较繁琐,使用 guava-retrying 可以帮我们灵活实现重试机制。

guava-retrying简介

guava-retrying 是一个线程安全的 Java 重试类库,提供了一种通用方法去处理任意需要重试的代码,可以方便灵活地控制重试次数、重试时机、重试频率、停止时机等,并具有异常处理功能

使用

1、dependency

<dependency>
  <groupId>com.github.rholder</groupId>
  <artifactId>guava-retrying</artifactId>
  <version>2.0.0</version>
</dependency>

2、定义重试器

两个重试器例子

重试器 retryer1: 失败后一直重试,以菲波纳耶数列设置重试等待间隔,直到间隔为1000s,然后以1000s为间隔重不断试

java 复制代码
private Retryer<Void> retryer1 = RetryerBuilder.<Void>newBuilder()
    .retryIfExceptionOfType(Throwable.class) // 如果出现Throwable异常则重试
    .withWaitStrategy(WaitStrategies.fibonacciWait(100, TimeUnit.SECONDS)) // 等待重试策略
    .withStopStrategy(StopStrategies.neverStop()) // 停止策略
    .build();

重试器 retryer2:重试3次后抛出异常,每次重试间隔等待300毫秒

java 复制代码
    private Retryer<Void> retryer2 = RetryerBuilder.<Void>newBuilder()
            .retryIfExceptionOfType(Throwable.class)
            .withWaitStrategy(WaitStrategies.fixedWait(300, TimeUnit.MILLISECONDS))
            .withStopStrategy(StopStrategies.stopAfterAttempt(3))
            .build();

参数定义

  • retryIfExceptionOfType():重试条件,另外还有 retryIfResult,retryIfRuntimeException
  • withWaitStrategy:重试等待策略
  • withStopStrategy:重试停止策略
  • 阻塞策略、超时限制、注册重试监听器(上述简易重试器未涉及到)

3、使用

retryer.call(() -> {
            log.info("重试方法被调用");
            if (1 == 1) {
                throw new RuntimeException("重试错误");
            }
            return null;
        });
相关推荐
Hacker_Oldv1 小时前
网络安全的学习路线
学习·安全·web安全
蒟蒻的贤1 小时前
vue学习11.21
javascript·vue.js·学习
高 朗1 小时前
【GO基础学习】基础语法(2)切片slice
开发语言·学习·golang·slice
码上有前1 小时前
解析后端框架学习:从单体应用到微服务架构的进阶之路
学习·微服务·架构
岳不谢2 小时前
VPN技术-VPN简介学习笔记
网络·笔记·学习·华为
海害嗨2 小时前
阿里巴巴官方「SpringCloudAlibaba全彩学习手册」限时开源!
学习·开源
小A1593 小时前
STM32完全学习——使用SysTick精确延时(阻塞式)
stm32·嵌入式硬件·学习
小A1593 小时前
STM32完全学习——使用标准库点亮LED
stm32·嵌入式硬件·学习
潜洋3 小时前
Spring Boot教程之五:在 IntelliJ IDEA 中运行第一个 Spring Boot 应用程序
java·spring boot·后端
朝九晚五ฺ4 小时前
【Linux探索学习】第十五弹——环境变量:深入解析操作系统中的进程环境变量
linux·运维·学习