1.guava-retrying 重试框架

一、核心定位

guava-retrying是基于Google Guava的重试框架,提供灵活的重试策略配置,解决Java项目中"失败重试"的通用场景(如接口调用超时、网络抖动、第三方服务不可用)。

二、核心组件

1. Retryer

重试执行器,通过 `call(Callable<T>)` 方法执行任务,触发重试逻辑。

2. RetryerBuilder

构建Retryer的核心工具,支持链式配置重试规则:

  • 重试条件(异常/返回值);

  • 等待策略;

  • 停止策略;

  • 监听器;

  • 超时控制。

3. 核心策略

|------|--------------------------|-----------------|
| 策略类型 | 常用实现 | 适用场景 |
| 等待策略 | FixedWaitStrategy | 内网接口,重试间隔固定 |
| | ExponentialWaitStrategy | 外网/第三方接口,避免高频重试 |
| | RandomWaitStrategy | 分布式场景,打散重试峰值 |
| 停止策略 | StopAfterAttemptStrategy | 按次数停止(最常用) |
| | StopAfterDelayStrategy | 按时长停止(如10秒内重试) |
| | NeverStopStrategy | 无限重试(仅适用于关键任务) |

三、核心API

  1. `retryIfException()`:所有RuntimeException重试;

  2. `retryIfExceptionOfType(Class<? extends Exception>)`:指定异常重试;

  3. `retryIfResult(Predicate<T>)`:基于返回值重试;

  4. `withWaitStrategy(WaitStrategy)`:配置等待策略;

  5. `withStopStrategy(StopStrategy)`:配置停止策略;

  6. `withRetryListener(RetryListener)`:配置监听器;

  7. `withAttemptTimeLimiter(AttemptTimeLimiter)`:配置单次任务超时。

四、使用场景

  • 第三方接口调用(如支付、短信、物流接口);

  • 分布式锁获取失败;

  • 数据库/缓存连接重试;

  • 消息队列发送失败重试。

相关推荐
wand codemonkey31 分钟前
SpringbootWeb【入门】+MySQL【安装】+【DataDrip安装 】+【连接MySQL】
java·mysql·mybatis
Mahir088 小时前
Spring 循环依赖深度解密:从问题本质到三级缓存源码级解析
java·后端·spring·缓存·面试·循环依赖·三级缓存
RyFit10 小时前
SpringAI 常见问题及解决方案大全
java·ai
石山代码10 小时前
C++ 内存分区 堆区
java·开发语言·c++
绝知此事10 小时前
【算法突围 01】线性结构与哈希表:后端开发的收纳术
java·数据结构·算法·面试·jdk·散列表
无风听海10 小时前
C# 隐式转换深度解析
java·开发语言·c#
一只大袋鼠11 小时前
Git 进阶(二):分支管理、暂存栈、远程仓库与多人协作
java·开发语言·git
德思特12 小时前
从 Dify 配置页理解 RAG 的重要参数
java·人工智能·llm·dify·rag
YOU OU12 小时前
Spring IoC&DI
java·数据库·spring
один but you12 小时前
从可变参数到 emplace:现代 C++ 性能优化的核心组合
java·开发语言