spring boot / cloud (七) 使用@Retryable來進行重處理

来源:http://www.cnblogs.com/itkk/archive/2017/08/29/7448643.html
-Advertisement-
Play Games

spring boot / cloud (七) 使用@Retryable來進行重處理 前言 什麼時候需要重處理? 在實際工作中,重處理是一個非常常見的場景,比如:發送消息失敗,調用遠程服務失敗,爭搶鎖失敗,等等,這些錯誤可能是因為網路波動造成的,等待過後重處理就能成功.通常來說,會用try/catc ...


spring boot / cloud (七) 使用@Retryable來進行重處理

前言

什麼時候需要重處理?

在實際工作中,重處理是一個非常常見的場景,比如:發送消息失敗,調用遠程服務失敗,爭搶鎖失敗,等等,這些錯誤可能是因為網路波動造成的,等待過後重處理就能成功.通常來說,會用try/catch,while迴圈之類的語法來進行重處理,但是這樣的做法缺乏統一性,並且不是很方便,要多寫很多代碼.然而spring-retry卻可以通過註解,在不入侵原有業務邏輯代碼的方式下,優雅的實現重處理功能.

思路

使用@Retryable和@Recover實現重處理,以及重處理失後的回調

實現

1.pom引用

<dependency>
  <groupId>org.springframework.retry</groupId>
  <artifactId>spring-retry</artifactId>
</dependency>

2.應用啟動類開啟retry

....其他註解
@EnableRetry
public class BaseApplication {
    .......
}

3.在指定方法上標記@Retryable來開啟重試

  @Retryable(value={A異常.class,B異常.class},
             maxAttempts=重試次數,
             backoff = @Backoff(value = 每次重試延遲毫秒數))
  public Integer retry() {
    final int a = 5;
    int num = new SecureRandom().nextInt();
    if (num % a == 0) {
      return num;
    }
    throw new RetryException("重試失敗");
  }

4.在指定方法上標記@Recover來開啟重試失敗後調用的方法(註意,需跟重處理方法在同一個類中)

  @Recover
  public void recover(A異常 e) {
    // ... do something
  }
  
  @Recover
  public void recover(B異常 e) {
    // ... do something
  }

代碼倉庫 (博客配套代碼)

結束

演示了單spring boot的應用的,在後續的cloud場景中,如:zuul,等組件,都會涉及到重處理,會在後續的章節中講解


想獲得最快更新,請關註公眾號

想獲得最快更新,請關註公眾號


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • virtualenv virtualenv用於創建獨立的Python環境,多個Python相互獨立,互不影響,它能夠:1. 在沒有許可權的情況下安裝新套件2. 不同應用可以使用不同的套件版本3. 套件升級不影響其他應用 安裝 使用方法 如,創建**ENV**的虛擬環境 預設情況下,虛擬環境會依賴系統環 ...
  • 使用 PoolingHttpClientConnectionManager 鏈接池管理類 ...
  • 以下函數列出某個目錄下(包括子目錄)所有文件,本隨筆重點不在於遞歸函數的實現,這是一個很簡單的遞歸,重點在於熟悉Python 庫os以及os.path一些函數的功能和用法 1. os.listdir(path):列出path下所有內容(包括文件和目錄,不包括.和..) 2. os.path.join ...
  • 最近在研究百度網盤的視頻解析,目的是找出網盤視頻的真實源地址。百度網盤對於超過1G的文件需要通過網盤客戶端下載,通過抓包研究,可下載源視頻有以下4個渠道: 一、https://pan.baidu.com/s/視頻地址 這是分享後的視頻地址 找到視頻源解析地址: 介面地址:https://pan.ba ...
  • 現要做一個簡單的登錄頁面,如果用戶通過驗證,會顯示Welcome用戶名的歡迎詞,反之則返回登錄頁面讓用戶再次輸入 這部分的完整代碼是JSPDemo項目里的login.jsp,下麵來分析一下關鍵代碼。 代碼位置 視頻位置 code/第3章/JSPDemo 視頻/第3章/JSP案例的講解 代碼位置 視頻 ...
  • 介面 什麼是介面 ? 介面只是定義了一些方法,而沒有去實現,多用於程式設計時,只是設計需要有什麼樣的功能,但是並沒有實現任何功能,這些功能需要被另一個類(B)繼承後,由 類B去實現其中的某個功能或全部功能。 個人的理解,多用於協作開發時,有不同的人在不同的類中實現介面中的各個方法。 在Python中 ...
  • 1.什麼是閉包(Closure)? 閉包是一個完整的設計功能模塊,可以在代碼中傳遞和使用,類似於Object-C的block(但是還是有區別,下麵會說明)或者其他語言的匿名函數(lambdas)。閉包可以捕獲或者儲存它們所在上下文的常量和變數。在Swift里等價於函數,是一等公民。 閉包有三種形式: ...
  • C++ 簡介 C++是一種靜態類型的、編譯式的、通用的、大小寫敏感的、不規則的變成語言,支持過程化編程、面向對象編程和泛型編程。被認為是一種中級語言。是C的一個超集,事實上任何合法的C程式都是合法的C++程式。 註:使用靜態類型的編程語言是在編譯時執行類型檢查,而不是在運行時執行類型檢查。 面向對象 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...