如何使用Spring RetryTemplate
在雲端計算場景中,網路是其中的一個重要部分。實際情況下的網路環境沒有開發環境的網路那麼穩定,所以在雲端計算中,網路是不可靠的已經成為了一條預設的潛規則。在系統研發的過程中,滿足正常的業務需求的必要前提下,系統的魯棒性,容錯性也成為了一個重要的技術需求。
在網路不可靠的環境中,要保證業務流程,就需要在網路異常時對流程異常環節進行重試處理。
Spring框架為我們提供了重試機制,接下來我們來試驗下Spring的重試。
Maven Dependency
假設專案是Maven管理的,需要在家pom中增加spring-retry包的依賴。
<dependency>
<groupId>org.springframework.retry</groupId>
<artifactId>spring-retry</artifactId>
</dependency>
建立Spring Retry Template
建立一個Bean配置類來管理bean,使用@EnableRetry來啟用Spring重試,通過@Bean註解建立一個RetryTemplate加入Spring Container。配置最大重試次數為4。
@Configuration
@EnableRetry
public class BeanSeederServices {
@Bean
public RetryTemplate retryTemplate() {
SimpleRetryPolicy retryPolicy = new SimpleRetryPolicy();
retryPolicy.setMaxAttempts(4);
FixedBackOffPolicy backOffPolicy = new FixedBackOffPolicy();
backOffPolicy.setBackOffPeriod(3000);
RetryTemplate template = new RetryTemplate();
template.setRetryPolicy(retryPolicy);
template.setBackOffPolicy(backOffPolicy);
return template;
}
}
構建重試邏輯
建立一個Service,在裡面使用我們構建的RetryTemplate,將需要重試的業務邏輯交給RetryTemplate。
@Service
public class ConfigureNetworkService
{
@Autowired
private RetryTemplate retryTemplate;
int counter =0;
private void configureNetworkSystem(){
retryTemplate.execute(
context -> {
verifyNwConfiguration();
return true;
});
}
private void verifyNwConfiguration(){
counter++;
LOGGER.info("N/W configuration Service Failed "+ counter);
throw new RuntimeException();
}
}
建立一個Controller,用來提供執行入口,通過url來觸發我們的重試功能。
@RestController
@RequestMapping(value="/networksrv")
public class NetworkClientService {
@Autowired
private ConfigureNetworkService configureNetworkService;
@GetMapping
public String callRetryService() throws SQLException {
return configureNetworkService.configureNetworkSystem();
}
}
在控制檯我們會看到Spring輸出的重試日誌
2020-06-16 09:59:51.399 INFO 17288 --- [nio-8080-exec-1] c.e.springretrydemo.NetworkClientService : N/W configuration Service Failed 1
2020-06-16 09:59:52.401 INFO 17288 --- [nio-8080-exec-1] c.e.springretrydemo.NetworkClientService : N/W configuration Service Failed 2
2020-06-16 09:59:53.401 INFO 17288 --- [nio-8080-exec-1] c.e.springretrydemo.NetworkClientService : N/W configuration Service Failed 3
2020-06-16 09:59:53.402 INFO 17288 --- [nio-8080-exec-1] c.e.springretrydemo.NetworkClientService : N/W configuration Service Failed 4
Exception in thread "NetworkClientService" java.lang.RuntimeException
總結
通過使用Spring RetryTemplate,我們只需要關心具體的業務邏輯,不在用開發重試處理邏輯了。
「其他文章」
- 2020新上市物業股:恆大金科融創領漲,金融街物業、燁星跌最狠 - 知乎
- 怎樣使用React Context API [每日前端夜話0x26]
- win10系統記憶體洩露記憶體居高不下但是實際又沒什麼程式佔記憶體的解決方案
- vtkSliderWidget: 3D
- 位運算的奇淫技巧,非常有趣~
- 從零開始的演算法學習生活——①高精度運算(2)
- Leetcode-Mysql題目及知識點總結(175.組合兩個表)
- 真正的高手都在講故事
- 微信8.0安卓內測版來了!!!
- LR匯出預設
- 如何解決在Linux tty終端中漢字方塊亂碼
- 網際網路企業部署BFF 框架的優勢
- Android 解決TextView設定文字和富文字SpannableString自動換行留空白問題
- JY06使用者組許可權管理
- Fabric遠端後臺執行耗時指令碼解決方法
- Sci-Hub重生了,這回用上了分散式網路 - 知乎
- EasyUI之EasyLoader載入器
- 優雅的物件轉換解決方案,為什麼更推薦 MapStruct 呢?
- 如何使用Spring RetryTemplate
- SQL注入學習記錄