精講RestTemplate第8篇-請求失敗自動重試機(jī)制

本文是精講RestTemplate第8篇被盈,前篇的blog訪問地址如下:

在上一節(jié)我們?yōu)榇蠹医榻B了锌畸,當(dāng)RestTemplate發(fā)起遠(yuǎn)程請求異常時(shí)的自定義處理方法巩步,我們可以通過自定義的方式解析出HTTP Status Code狀態(tài)碼虱饿,然后根據(jù)狀態(tài)碼和業(yè)務(wù)需求決定程序下一步該如何處理。
本節(jié)為大家介紹另外一種通用的異常的處理機(jī)制:那就是自動重試绷跑。也就是說拳恋,在RestTemplate發(fā)送請求得到非200狀態(tài)結(jié)果的時(shí)候,間隔一定的時(shí)間再次發(fā)送n次請求砸捏。n次請求都失敗之后谬运,最后拋出HttpClientErrorException隙赁。
在開始本節(jié)代碼之前,將上一節(jié)的RestTemplate自定義異常處理的代碼注釋掉梆暖,否則自動重試機(jī)制不會生效伞访。如下(參考上一節(jié)代碼):

//restTemplate.setErrorHandler(new MyRestErrorHandler());

一、Spring Retry配置生效

通過maven坐標(biāo)引入spring-retry轰驳,spring-retry的實(shí)現(xiàn)依賴于面向切面編程厚掷,所以引入aspectjweaver。以下配置過程都是基于Spring Boot應(yīng)用级解。

<dependency>
    <groupId>org.springframework.retry</groupId>
    <artifactId>spring-retry</artifactId>
    <version>1.2.5.RELEASE</version>
</dependency>
<dependency>
   <groupId>org.aspectj</groupId>
   <artifactId>aspectjweaver</artifactId>
</dependency>

在Spring Boot 應(yīng)用入口啟動類冒黑,也就是配置類的上面加上@SpringRetry注解,表示讓重試機(jī)制生效勤哗。

二薛闪、使用案例

@Service
public class RetryService {


  @Resource
  private RestTemplate restTemplate;

  private static final DateTimeFormatter DATE_TIME_FORMATTER = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");


  @Retryable(value = RestClientException.class, maxAttempts = 3,
          backoff = @Backoff(delay = 5000L,multiplier = 2))
  public HttpStatus testEntity() {
    System.out.println("發(fā)起遠(yuǎn)程API請求:" + DATE_TIME_FORMATTER.format(LocalDateTime.now()));
    
    String url = "http://jsonplaceholder.typicode.com/postss/1";
    ResponseEntity<String> responseEntity
            = restTemplate.getForEntity(url, String.class);

    return responseEntity.getStatusCode(); // 獲取響應(yīng)碼
  }


}
  • @Retryable注解的方法在發(fā)生異常時(shí)會重試苔可,參數(shù)說明:
    • value:當(dāng)指定異常發(fā)生時(shí)會進(jìn)行重試 ,HttpClientErrorException是RestClientException的子類缴挖。
    • include:和value一樣,默認(rèn)空焚辅。如果 exclude也為空時(shí)映屋,所有異常都重試
    • exclude:指定異常不重試,默認(rèn)空同蜻。如果 include也為空時(shí)棚点,所有異常都重試
    • maxAttemps:最大重試次數(shù),默認(rèn)3
    • backoff:重試等待策略湾蔓,默認(rèn)空
  • @Backoff注解為重試等待的策略瘫析,參數(shù)說明:
    • delay:指定重試的延時(shí)時(shí)間,默認(rèn)為1000毫秒
    • multiplier:指定延遲的倍數(shù)默责,比如設(shè)置delay=5000贬循,multiplier=2時(shí),第一次重試為5秒后桃序,第二次為10(5x2)秒杖虾,第三次為20(10x2)秒。

寫一個(gè)測試的RetryController 對RetryService 的testEntity方法進(jìn)行調(diào)用

@RestController
public class RetryController {
 
    @Resource
    private RetryService retryService;
 
    @GetMapping("/retry")
    public HttpStatus test() {
        return retryService.testEntity();
    }
}

三媒熊、測試結(jié)果

http://localhost:8080/retry 發(fā)起請求奇适,結(jié)果如下:

從結(jié)果可以看出:

  • 第一次請求失敗之后坟比,延遲5秒后重試
  • 第二次請求失敗之后,延遲10秒后重試
  • 第三次請求失敗之后滤愕,拋出異常

歡迎關(guān)注我的博客温算,里面有很多精品合集

  • 本文轉(zhuǎn)載注明出處(必須帶連接,不能只轉(zhuǎn)文字):字母哥博客间影。

覺得對您有幫助的話注竿,幫我點(diǎn)贊、分享魂贬!您的支持是我不竭的創(chuàng)作動力巩割! 。另外付燥,筆者最近一段時(shí)間輸出了如下的精品內(nèi)容宣谈,期待您的關(guān)注。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末键科,一起剝皮案震驚了整個(gè)濱河市闻丑,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌勋颖,老刑警劉巖嗦嗡,帶你破解...
    沈念sama閱讀 212,383評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異饭玲,居然都是意外死亡侥祭,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,522評論 3 385
  • 文/潘曉璐 我一進(jìn)店門茄厘,熙熙樓的掌柜王于貴愁眉苦臉地迎上來矮冬,“玉大人,你說我怎么就攤上這事次哈√ナ穑” “怎么了?”我有些...
    開封第一講書人閱讀 157,852評論 0 348
  • 文/不壞的土叔 我叫張陵窑滞,是天一觀的道長硝拧。 經(jīng)常有香客問我,道長葛假,這世上最難降的妖魔是什么障陶? 我笑而不...
    開封第一講書人閱讀 56,621評論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮聊训,結(jié)果婚禮上抱究,老公的妹妹穿的比我還像新娘。我一直安慰自己带斑,他們只是感情好鼓寺,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,741評論 6 386
  • 文/花漫 我一把揭開白布勋拟。 她就那樣靜靜地躺著,像睡著了一般妈候。 火紅的嫁衣襯著肌膚如雪敢靡。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,929評論 1 290
  • 那天苦银,我揣著相機(jī)與錄音啸胧,去河邊找鬼。 笑死幔虏,一個(gè)胖子當(dāng)著我的面吹牛纺念,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播想括,決...
    沈念sama閱讀 39,076評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼陷谱,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了瑟蜈?” 一聲冷哼從身側(cè)響起烟逊,我...
    開封第一講書人閱讀 37,803評論 0 268
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎铺根,沒想到半個(gè)月后宪躯,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,265評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡夷都,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,582評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了予颤。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片囤官。...
    茶點(diǎn)故事閱讀 38,716評論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖蛤虐,靈堂內(nèi)的尸體忽然破棺而出党饮,到底是詐尸還是另有隱情,我是刑警寧澤驳庭,帶...
    沈念sama閱讀 34,395評論 4 333
  • 正文 年R本政府宣布刑顺,位于F島的核電站,受9級特大地震影響饲常,放射性物質(zhì)發(fā)生泄漏蹲堂。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,039評論 3 316
  • 文/蒙蒙 一贝淤、第九天 我趴在偏房一處隱蔽的房頂上張望柒竞。 院中可真熱鬧,春花似錦播聪、人聲如沸朽基。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,798評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽稼虎。三九已至衅檀,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間霎俩,已是汗流浹背哀军。 一陣腳步聲響...
    開封第一講書人閱讀 32,027評論 1 266
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留茸苇,地道東北人排苍。 一個(gè)月前我還...
    沈念sama閱讀 46,488評論 2 361
  • 正文 我出身青樓,卻偏偏與公主長得像学密,于是被迫代替她去往敵國和親淘衙。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,612評論 2 350