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

四、使用场景

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

  • 分布式锁获取失败;

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

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

相关推荐
运维@小兵8 小时前
Spring AI入门
java·人工智能·spring
Geoking.8 小时前
【设计模式】策略模式(Strategy)详解:把 if-else 变成可切换的算法
java·设计模式·策略模式
代码改变生活-1209 小时前
idea 清除缓存之后重启项目编译失败
java·缓存·intellij-idea
Microsoft Word9 小时前
HashMap面试题总结
java·开发语言
stillaliveQEJ9 小时前
【MyBatis】DML映射
java·mybatis
qq_12498707539 小时前
基于SSM框架的智能密室逃脱信息管理系统(源码+论文+部署+安装)
java·大数据·人工智能·spring boot·后端·毕业设计·计算机毕业设计
ekkcole9 小时前
java实现对excel文件合并单元格(只针对文件)
java·开发语言·excel
no24544109 小时前
RAGFlow 全面接入 MinerU 2.0,支持 pipeline、vlm-transformers、vlm-sglang 三种模式,解析精度大幅度up
java·大数据·人工智能·python·ai·sglang
lkbhua莱克瓦249 小时前
MySQL事务隔离级别:从并发混乱到数据一致性守护者
java·数据库·mysql·隔离级别