Spring Retry 异常重试机制:从入门到生产实践

适用版本:Spring Boot 3.x + spring-retry 2.x
本文覆盖 注解声明式RetryTemplate 编程式监听器最佳实践避坑清单,可直接落地生产。


一、核心坐标

<!-- Spring Boot Starter 已经帮你管理版本 -->
<dependency><groupId>org.springframework.retry</groupId><artifactId>spring-retry</artifactId>
</dependency>
<!-- AOP 支持 -->
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-aop</artifactId>
</dependency>

二、开启重试能力

在启动类或任意 @Configuration 上添加:

@SpringBootApplication
@EnableRetry        // <-- 只需这一行
public class Application { }

三、注解式:最常用 80% 场景

3.1 基本用法

@Service
public class OrderService {@Retryable(retryFor = ConnectException.class,   // 触发重试的异常maxAttempts = 3,                     // 含首次,共 3 次backoff = @Backoff(delay = 1000,                    // 首次延迟 1smultiplier = 1.5                // 指数退避 1→1.5→2.25s))public void pay(int orderId) throws ConnectException {// 模拟远程调用throw new ConnectException("网络抖动");}
}

3.2 兜底恢复

@Recover
public void payRecover(ConnectException e, int orderId) {log.error("订单 {} 支付失败,进入补偿流程", orderId);// 发消息、记录表、人工审核...
}

注意@Recover 方法签名必须与 @Retryable 一致(异常类型 + 参数 + 返回值),否则不生效 。


四、编程式:RetryTemplate 细粒度控制

适用于 动态策略无 Spring Bean 场景

@Configuration
public class RetryConfig {@Beanpublic RetryTemplate retryTemplate() {return RetryTemplate.builder().maxAttempts(5).exponentialBackoff(1000, 1.5, 10000) // 初始 1s、乘 1.5、最大 10s.retryOn(ConnectException.class).build();}
}@Service
public class ReportService {@Autowiredprivate RetryTemplate retryTemplate;public String generate() {return retryTemplate.execute(ctx -> {// 模板内部自动重试return remoteClient.generate();});}
}

五、监听重试生命周期

实现 RetryListener 可以 记录指标 / 报警 / 链路追踪

@Component
public class RetryLogger implements RetryListener {@Overridepublic <T, E extends Throwable> void onError(RetryContext ctx,RetryCallback<T, E> callback,Throwable throwable) {log.warn("第 {} 次重试失败: {}", ctx.getRetryCount(), throwable.getMessage());}
}

注册到模板:

retryTemplate.registerListener(new RetryLogger());

六、生产级最佳实践

维度建议
重试场景仅对 网络、锁、瞬时故障;业务校验失败不重试
次数 & 退避3~5 次 + 指数退避,避免雪崩
幂等性写操作需保证 幂等键 / 去重表
超时控制方法级别设置 timeout,防止长时间阻塞
监控告警通过 Micrometer + RetryListener 导出 重试次数、成功率

七、常见踩坑清单

症状原因解决
重试不触发直接 new 调用 / 异常被吃掉必须走 Spring 代理抛出异常
@Recover 不执行签名不一致保持异常类型、参数、返回值一致
无限重试maxAttempts = Integer.MAX_VALUE显式设置合理上限
线程阻塞退避策略未设 maxDelay设置最大等待时间

八、小结一句话

Spring Retry 通过 注解 + AOPRetryTemplate 提供声明式/编程式重试,在 可观测、可配置、无侵入 的前提下极大提升了分布式系统的健壮性;
牢记“次数、退避、幂等、监控”四要素,即可安全落地生产。

完整示例代码已上传 GitHub:
https://github.com/your-org/spring-retry-demo

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/web/90865.shtml
繁体地址,请注明出处:http://hk.pswp.cn/web/90865.shtml
英文地址,请注明出处:http://en.pswp.cn/web/90865.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

VTK交互——CallData

0. 概要 这段代码https://examples.vtk.org/site/Cxx/Interaction/CallData/是一个使用VTK(Visualization Toolkit)库的示例程序,主要演示了自定义事件、回调函数和定时器的使用。程序创建一个旋转球体场景,并通过定时器触发自定义事件来更新计数器。以下是详细解释: 1.…

OCR工具集下载与保姆级安装教程!!

软件下载 软件名称&#xff1a;OCR工具集1.1 软件语言&#xff1a;简体中文 软件大小&#xff1a;78.8M 系统要求&#xff1a;Windows7或更高&#xff0c; 32/64位操作系统 硬件要求&#xff1a;CPU2GHz &#xff0c;RAM4G或更高 盘丨下载&#xff1a;https://tool.nineya…

平时遇到的错误码及场景?404?400?502?都是什么场景下什么含义,该怎么做 ?

✅ 一、常见 HTTP 错误码及含义状态码含义简述类型400Bad Request&#xff1a;请求格式有误客户端错误401Unauthorized&#xff1a;未授权客户端错误403Forbidden&#xff1a;禁止访问客户端错误404Not Found&#xff1a;资源不存在客户端错误405Method Not Allowed&#xff1a…

基于Tornado的WebSocket实时聊天系统:从零到一构建与解析

引言 在当今互联网应用中&#xff0c;实时通信已成为不可或缺的一部分。无论是社交媒体、在线游戏还是协同办公&#xff0c;用户都期待即时、流畅的交互体验。传统的HTTP协议是无状态的、单向的请求-响应模式&#xff0c;客户端发起请求&#xff0c;服务器返回响应&#xff0c…

【语义分割】记录2:yolo系列

图像分割笔记1、源码下载2、数据获取3、环境配置4、模型训练5、模型推理6、模型部署6.1 yolov5_flask学习7、版本上传1、源码下载 git clone https://github.com/ultralytics/ultralytics.gitgit回到对应版本&#xff1a; 方式一&#xff1a;使用 git checkout&#xff08;临…

ubuntu22.04系统 算力4090服务器 病毒防护 查杀等 运维入门(三)clamAV工具离线查杀

以下有免费的4090云主机提供ubuntu22.04系统的其他入门实践操作 地址&#xff1a;星宇科技 | GPU服务器 高性能云主机 云服务器-登录 相关兑换码星宇社区---4090算力卡免费体验、共享开发社区-CSDN博客 兑换码要是过期了&#xff0c;可以私信我获取最新兑换码&#xff01;&a…

微信小程序文件下载与预览功能实现详解

在微信小程序开发中&#xff0c;文件处理是常见需求&#xff0c;尤其是涉及合同、文档等场景。本文将通过一个实际案例&#xff0c;详细讲解如何实现文件的下载、解压、列表展示及预览功能。 功能概述 该页面主要实现了以下核心功能&#xff1a; 列表展示可下载的文件信息支持 …

postgresql执行创建和删除时遇到的问题

删除数据库的时候出现的问题 有连接在占用 postgres=# DROP DATABASE "subgraph-dev"; ERROR: database "subgraph-dev" is being accessed by other users DETAIL: There is 1 other session using the database.强制断开在用的连接 -- 替换 subgraph…

linux 应用层直接操作GPIO的方法

了解&#xff01;你使用的是 Rockchip RK3588S 平台&#xff0c;需要操作 GPIO3_D5_d 这个引脚&#xff08;即 MCU_JTAG_TMS_M1/.../GPIO3_D5_d&#xff09;。以下是基于你提供的系统信息的具体操作步骤&#xff1a;&#x1f50d; 第一步&#xff1a;确认 GPIO 系统编号 在 RK3…

JavaScript核心概念全解析

目录 1. 作用域 (1) 局部作用域 (2) 全局作用域 2. 垃圾回收 (1) 引用计数法 (2) 标记清除法 3. 闭包 (1) 作用 (2) 风险 4. 变量提升 (1) var (2) let 和 const (3) const 5. 函数提升 (1) 函数声明 (2) 函数表达式 6. 函数参数 (1) 动态参数 (2) 剩余参数…

力扣刷题(第一百天)

灵感来源 - 保持更新&#xff0c;努力学习- python脚本学习提莫攻击解题思路初始化总中毒时间 total。遍历每次攻击的时间点&#xff08;从第二个开始&#xff09;&#xff1a;计算当前攻击与前一次攻击的时间间隔 gap。若 gap < duration&#xff0c;则本次中毒时间为 gap&…

JMeter 性能测试实战笔记

JMeter 性能测试实战笔记 本文档是一份详细的 JMeter 指南&#xff0c;涵盖了从创建测试计划、执行测试到解读性能结果的全过程。 一、创建测试计划 一个完整的测试计划是执行性能测试的基础。下面将分步介绍如何创建一个针对文件上传接口的测试场景。 第一步&#xff1a;添加线…

图像处理:第二篇 —— 选择镜头的基础知识及对图像处理的影响

一、图像传感器的典型应用图像处理过程大致可分为如下四步&#xff1a;1.拍 摄 按下快门&#xff0c;拍摄图像2.传 送 将图像数据由照相机传送到控制器。3.处 理 前处理 : 对于图像数据进行加工&#xff0c;使其特征更加明显。测算处理 : 根据图像数据对于损…

Linux 系统文件夹结构及用途说明

Linux 系统采用树形文件结构&#xff0c;每个目录都有明确的功能定位&#xff0c;遵循 FHS&#xff08;Filesystem Hierarchy Standard&#xff09; 标准。以下是新安装系统后主要文件夹的用途&#xff1a;一、根目录&#xff08;/&#xff09;核心文件夹1. /bin&#xff1a;基…

[spring6: HttpSecurity]-全新写法

HttpSecurity HttpSecurity 是 Spring Security 中用于配置基于 HTTP 请求的安全策略的核心构建器&#xff0c;支持细粒度控制请求授权、认证、登录、登出、CSRF、CORS、会话管理等安全功能。 package xyz.idoly.demo;import org.springframework.context.annotation.Bean; imp…

MIPI DSI 转 1LVDS ,分辨率1920*1080.

一款桥接芯片&#xff0c;它接收 MP DSI 输入并发送 LVDS 输出。MlPI DSI 支持至多 4 条通道&#xff0c;每条通道的最大传输速率为 1Gbps&#xff0c;总的最大输入带宽为 4Gbps&#xff0c;并且还支持 MlPI 定义的 ULPS&#xff08;超低功耗状态&#xff09;。LVDS 输出采用 V…

墨者:SQL手工注入漏洞测试(MySQL数据库)

一、SQL手工注入漏洞测试(MySQL数据库) 本文以墨者学院靶场为例&#xff0c;演示MySQL数据库的手工SQL注入全过程。靶场以自己的地址为准&#xff1a;http://124.70.64.48:47777/new_list.php?id1 二、注入原理与流程&#xff08;如下指令去掉了id之前的内容&#xff09; M…

idea打开后project窗口未显示项目名称的解决方案

前言 今天上班后&#xff0c;打开了idea发现之前project窗口中的项目都不见了&#xff0c;啥也没有&#xff0c;见下图原因 一般为配置文件*.iml 出错了。 解决方案1 方法1&#xff1a;若知道出错的具体位置与原因&#xff0c;用文本编辑器打开*.iml文件&#xff0c;找到出错位…

不一样的Mysql安装方式

文章目录MySQL介绍与安装MySQL介绍基本安装下载打开网址点击点击选择LTSwindows选择zip压缩包格式&#xff0c;mac OS选择dmg格式。不需要注册登陆网站&#xff0c;直接谢谢&#xff0c;继续下载即可。解压复制bin路径配置环境变量搜索点击环境变量点击用户变量的Path 或 系统变…

MyBatis高级应用实战指南

MyBatis高级应用实例 以下是MyBatis高级应用实例,涵盖复杂查询、动态SQL、插件开发、缓存优化等场景,帮助深入掌握MyBatis核心技术。 动态SQL构建 Example 1: 多条件动态查询 使用<if>和<where>标签实现条件组合: <select id="findUsers" resu…