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

四、使用场景

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

  • 分布式锁获取失败;

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

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

相关推荐
lkbhua莱克瓦242 小时前
反射4-反射获取成员变量
java·开发语言·servlet·反射
lifewange2 小时前
Linux 日志查看命令速查表
java·linux·运维
风景的人生2 小时前
一台电脑上可以同时运行多个JVM(Java虚拟机)实例
java·开发语言·jvm
阿蒙Amon2 小时前
C#每日面试题-进程和线程的区别
java·面试·c#
一 乐2 小时前
养老院信息|基于springboot + vue养老院信息管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端
hopsky3 小时前
mvn install 需要 手动清除 pom.lastUpdated
java·maven·mavbne
5980354153 小时前
【java工具类】小数、整数转中文小写
android·java·开发语言
cike_y3 小时前
Mybatis之作用域(Scope)和生命周期-解决属性名和字段名不一致的问题&ResultMap结果集映射
java·开发语言·数据库·tomcat·mybatis
天远Date Lab3 小时前
构建金融级信贷审批系统:Java Spring Boot 集成天远借贷行为验证 API 全指南
java·大数据·spring boot·金融