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)`:配置单次任务超时。

四、使用场景

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

  • 分布式锁获取失败;

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

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

相关推荐
karry_k5 小时前
MyBatis批量insert-select踩坑:useGeneratedKeys=true 可能让PostgreSQL返回大量插入结果
java·后端
karry_k6 小时前
PostgreSQL 在 MyBatis 中执行正常 SQL 失效:一次 DELETE USING 踩坑记录
java·后端
SamDeepThinking9 小时前
从源码到代码:MyBatis-Flex 与 MyBatis-Plus 的逐项对比
java·后端·程序员
她的男孩12 小时前
Spring Boot 接 Flowable 工作流:用 3 个注解搭一个请假审批流程
java·后端·架构
荣码14 小时前
LLM结构化输出:让AI返回JSON而不是废话,我踩了4个坑
java·python
plainGeekDev15 小时前
Gson → kotlinx.serialization
android·java·kotlin
小bo波1 天前
Java Swing 图形用户界面实验 —— 从算术练习到游戏开发的完整实践
java·课程设计·gui·游戏开发·扫雷·swing
咖啡八杯1 天前
GoF设计模式——备忘录模式
java·后端·spring·设计模式