精講RestTemplate第8篇-請求失敗自動重試機制
阿新 • • 發佈:2020-08-15
本文是精講RestTemplate第8篇,前篇的blog訪問地址如下:
* [精講RestTemplate第1篇-在Spring或非Spring環境下如何使用](http://www.zimug.com/java/spring/%e7%b2%be%e8%ae%b2resttemplate%e7%ac%ac1%e7%af%87-%e5%9c%a8spring%e6%88%96%e9%9d%9espring%e7%8e%af%e5%a2%83%e4%b8%8b%e5%a6%82%e4%bd%95%e4%bd%bf%e7%94%a8/.html)
* [精講RestTemplate第2篇-多種底層HTTP客戶端類庫的切換](http://www.zimug.com/java/spring/%e7%b2%be%e8%ae%b2resttemplate%e7%ac%ac2%e7%af%87-%e5%a4%9a%e7%a7%8d%e5%ba%95%e5%b1%82http%e5%ae%a2%e6%88%b7%e7%ab%af%e7%b1%bb%e5%ba%93%e7%9a%84%e5%88%87%e6%8d%a2/.html)
* [精講RestTemplate第3篇-GET請求使用方法詳解](http://www.zimug.com/java/spring/%e7%b2%be%e8%ae%b2resttemplate%e7%ac%ac3%e7%af%87-get%e8%af%b7%e6%b1%82%e4%bd%bf%e7%94%a8%e6%96%b9%e6%b3%95%e8%af%a6%e8%a7%a3/.html)
* [精講RestTemplate第4篇-POST請求方法使用詳解](http://www.zimug.com/java/spring/%e7%b2%be%e8%ae%b2resttemplate%e7%ac%ac4%e7%af%87-post%e8%af%b7%e6%b1%82%e6%96%b9%e6%b3%95%e4%bd%bf%e7%94%a8%e8%af%a6%e8%a7%a3/.html)
* [精講RestTemplate第5篇-DELETE、PUT等請求方法使用詳解](http://www.zimug.com/java/%e7%b2%be%e8%ae%b2resttemplate%e7%ac%ac4%e7%af%87-delete%e3%80%81put%e7%ad%89%e8%af%b7%e6%b1%82%e6%96%b9%e6%b3%95%e4%bd%bf%e7%94%a8%e8%af%a6%e8%a7%a3/.html)
* [精講RestTemplate第6篇-檔案上傳下載與大檔案流式下載](http://www.zimug.com/java/spring/%e7%b2%be%e8%ae%b2resttemplate%e7%ac%ac6%e7%af%87-%e6%96%87%e4%bb%b6%e4%b8%8a%e4%bc%a0%e4%b8%8b%e8%bd%bd%e4%b8%8e%e5%a4%a7%e6%96%87%e4%bb%b6%e6%b5%81%e5%bc%8f%e4%b8%8b%e8%bd%bd/.html)
* [精講RestTemplate第7篇-自定義請求失敗異常處理](http://www.zimug.com/java/spring/%e7%b2%be%e8%ae%b2resttemplate%e7%ac%ac7%e7%af%87-%e8%87%aa%e5%ae%9a%e4%b9%89%e8%af%b7%e6%b1%82%e5%a4%b1%e8%b4%a5%e5%bc%82%e5%b8%b8%e5%a4%84%e7%90%86/.html)
在上一節我們為大家介紹了,當RestTemplate發起遠端請求異常時的自定義處理方法,我們可以通過自定義的方式解析出HTTP Status Code狀態碼,然後根據狀態碼和業務需求決定程式下一步該如何處理。
本節為大家介紹另外一種通用的異常的處理機制:那就是自動重試。也就是說,在RestTemplate傳送請求得到非200狀態結果的時候,間隔一定的時間再次傳送n次請求。n次請求都失敗之後,最後丟擲HttpClientErrorException。
在開始本節程式碼之前,將上一節的RestTemplate自定義異常處理的程式碼註釋掉,否則自動重試機制不會生效。如下(參考上一節程式碼):
~~~
//restTemplate.setErrorHandler(new MyRestErrorHandler());
~~~
## 一、Spring Retry配置生效
通過maven座標引入spring-retry,spring-retry的實現依賴於面向切面程式設計,所以引入aspectjweaver。以下配置過程都是基於Spring Boot應用。
~~~
~~~
在Spring Boot 應用入口啟動類,也就是配置類的上面加上@SpringRetry註解,表示讓重試機制生效。
![](https://img2020.cnblogs.com/other/1815316/202008/1815316-20200815104820642-1352934444.png)
## 二、使用案例
* 寫一個模擬的業務類RetryService ,在其裡面注入RestTemplate 。RestTemplate 例項化Bean配置參考: [《精講RestTemplate第1篇-在Spring或非Spring環境下如何使用》](http://www.zimug.com/java/spring/%e7%b2%be%e8%ae%b2resttemplate%e7%ac%ac1%e7%af%87-%e5%9c%a8spring%e6%88%96%e9%9d%9espring%e7%8e%af%e5%a2%83%e4%b8%8b%e5%a6%82%e4%bd%95%e4%bd%bf%e7%94%a8/.html) 和 [《精講RestTemplate第2篇-多種底層HTTP客戶端類庫的切換》](http://www.zimug.com/java/spring/%e7%b2%be%e8%ae%b2resttemplate%e7%ac%ac2%e7%af%87-%e5%a4%9a%e7%a7%8d%e5%ba%95%e5%b1%82http%e5%ae%a2%e6%88%b7%e7%ab%af%e7%b1%bb%e5%ba%93%e7%9a%84%e5%88%87%e6%8d%a2/.html) 進行實現。
* 將正確的請求服務地址由“/posts/1”改成“/postss/1”。服務不存在所以丟擲404異常,是為了觸發重試機制。
~~~
@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("發起遠端API請求:" + DATE_TIME_FORMATTER.format(LocalDateTime.now()));
String url = "http://jsonplaceholder.typicode.com/postss/1";
Respon