Spring boot使用spring retry重試機(jī)制的方法示例
當(dāng)我們調(diào)用接口的時候由于網(wǎng)絡(luò)原因可能失敗,再嘗試就成功了,這就是重試機(jī)制。非冪等的情況下要小心使用重試。
tips:冪等性
HTTP/1.1中對冪等性的定義是:一次和多次請求某一個資源對于資源本身應(yīng)該具有同樣的結(jié)果(網(wǎng)絡(luò)超時等問題除外)。也就是說,其任意多次執(zhí)行對資源本身所產(chǎn)生的影響均與一次執(zhí)行的影響相同。
注解方式使用Spring Retry
(一)Maven依賴
<!-- 重試機(jī)制 --> <dependency> <groupId>org.springframework.retry</groupId> <artifactId>spring-retry</artifactId> <version>1.2.4.RELEASE</version> </dependency> <dependency> <groupId>org.aspectj</groupId> <artifactId>aspectjweaver</artifactId> <version>1.9.4</version> </dependency>
(二)配置類添加注解 @EnableRetry
@EnableRetry @Configuration public class RetryConfiguration { }
(三)Service方法編寫
@Retryable注解:
value: 拋出指定異常才會重試
include:和value一樣,默認(rèn)為空,當(dāng)exclude也為空時,默認(rèn)所以異常
exclude:指定不處理的異常
maxAttempts:最大重試次數(shù),默認(rèn)3次
backoff:重試等待策略,默認(rèn)使用@Backoff,@Backoff的value默認(rèn)為1000L;multiplier(指定延遲倍數(shù))
@Recover注解:
當(dāng)重試達(dá)到指定次數(shù)時候該注解的方法將被回調(diào)
發(fā)生的異常類型需要和@Recover注解的參數(shù)一致
@Retryable注解的方法不能有返回值,不然@Recover注解的方法無效
@Service public class RetryService { private Logger logger = LoggerFactory.getLogger(RetryService.class); @Retryable(value = Exception.class, maxAttempts = 3, backoff = @Backoff(delay = 2000L, multiplier = 2)) public void devide(double a, double b){ logger.info("開始進(jìn)行除法運(yùn)算"); if (b == 0) { throw new RuntimeException(); } logger.info("{} / {} = {}", a, b, a / b); } @Recover public void recover() { logger.error("被除數(shù)不能為0"); } }
(四)測試
@RunWith(SpringRunner.class) @SpringBootTest public class BootdemoApplicationTests { @Autowired private RetryService retryService; private Logger logger = LoggerFactory.getLogger(BootdemoApplication.class); @Test public void retryTest() { //int count = retryService.retry(-1); retryService.retry(-1); //logger.info("庫存為:" + count); } }
注意事項(xiàng)
@Retryable不能在本類使用,不然不會生效。如果直接調(diào)用execute重試機(jī)制將不會生效,調(diào)用devide則重試生效。
public void execute(double a, double b) throws DevideException { devide(a, b); } @Retryable(value = DevideException.class, maxAttempts = 3, backoff = @Backoff(delay = 2000L, multiplier = 2)) public void devide(double a, double b) throws DevideException { logger.info("開始進(jìn)行除法運(yùn)算"); if (b == 0) { throw new DevideException("被除數(shù)不能為0"); } logger.info("{} / {} = {}", a, b, a / b); }
使用@Retryable不能使用try catch捕獲異常為簡單
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持我們。
上一篇:簡單了解java標(biāo)識符的作用和命名規(guī)則
欄 目:Java
本文標(biāo)題:Spring boot使用spring retry重試機(jī)制的方法示例
本文地址:http://mengdiqiu.com.cn/a1/Java/8762.html
您可能感興趣的文章
- 01-10Springboot中@Value的使用詳解
- 01-10使用Swing繪制動態(tài)時鐘
- 01-10springboot實(shí)現(xiàn)文件上傳步驟解析
- 01-10springboot jta atomikos實(shí)現(xiàn)分布式事物管理
- 01-10JAVA8獨(dú)有的map遍歷方式(非常好用)
- 01-10SpringBoot使用RabbitMQ延時隊(duì)列(小白必備)
- 01-10如何基于SpringBoot部署外部Tomcat過程解析
- 01-10SPRING BOOT啟動命令參數(shù)及源碼詳析
- 01-10springboot集成fastDfs過程代碼實(shí)例
- 01-10Java使用Scanner類進(jìn)行控制臺輸入實(shí)現(xiàn)方法


閱讀排行
本欄相關(guān)
- 01-10Java實(shí)現(xiàn)動態(tài)模擬時鐘
- 01-10Springboot中@Value的使用詳解
- 01-10JavaWeb實(shí)現(xiàn)郵件發(fā)送功能
- 01-10利用Java實(shí)現(xiàn)復(fù)制Excel工作表功能
- 01-10Java實(shí)現(xiàn)動態(tài)數(shù)字時鐘
- 01-10java基于poi導(dǎo)出excel透視表代碼實(shí)例
- 01-10java實(shí)現(xiàn)液晶數(shù)字字體顯示當(dāng)前時間
- 01-10基于Java驗(yàn)證jwt token代碼實(shí)例
- 01-10Java動態(tài)顯示當(dāng)前日期和時間
- 01-10淺談Java中真的只有值傳遞么
隨機(jī)閱讀
- 01-11ajax實(shí)現(xiàn)頁面的局部加載
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 01-10delphi制作wav文件的方法
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 01-10C#中split用法實(shí)例總結(jié)
- 04-02jquery與jsp,用jquery