Spring Retry 異常重試機制:從入門到生產實踐

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…