当我们调用接口的时候由于网络原因可能失败,再尝试就成功了,这就是重试机制。非幂等的情况下要小心使用重试。
HTTP/1.1中对幂等性的定义是:一次和多次请求某一个资源对于资源本身应该具有同样的结果(网络超时等问题除外)。也就是说,其任意多次执行对资源本身所产生的影响均与一次执行的影响相同。
(一)Maven依赖
& lt; !——重试机制——比; & lt; dependency> & lt; groupId> org.springframework.retry & lt; artifactId> spring-retry & lt; version> 1.2.4.RELEASE & lt;/dependency> & lt; dependency> & lt; groupId> org.aspectj & lt; artifactId> aspectjweaver & lt; version> 1.9.4 & lt;/dependency> >之前(二)配置类添加注解@EnableRetry
@EnableRetry @ configuration 公开课RetryConfiguration { } >之前(三)服务方法编写
@Retryable注解:
值:抛出指定异常才会重试
包括:和价值一样,默认为空,当排除也为空时,默认所以异常
排除:指定不处理的异常
maxAttempts:最大重试次数,默认3次
倒扣:重试等待策略,默认使用@Backoff, @Backoff的价值默认为1000 l;乘数(指定延迟倍数)
@Recover注解:
当重试达到指定次数时候该注解的方法将被回调
发生的异常类型需要和@Recover注解的参数一致
@Retryable注解的方法不能有返回值,不然@Recover注解的方法无效
@ service 公开课RetryService { 私人日志记录器=LoggerFactory.getLogger (RetryService.class); @Retryable(值=https://www.yisu.com/zixun/Exception.class, maxAttempts=3,倒扣=@Backoff(延迟=2000 l,乘数=2)) 公共空间除号(双,双b) { logger.info(“开始进行除法运算”); if (b==0) { 把新RuntimeException (); } logger.info (“{}/{}={} ", a, b, a/b); } @Recover 公共空间恢复(){ logger.error(“被除数不能为0”); } } >之前(四)测试
@RunWith (SpringRunner.class) @SpringBootTest 公开课BootdemoApplicationTests { @ autowired 私人RetryService RetryService; 私人日志记录器=LoggerFactory.getLogger (BootdemoApplication.class); @Test 公共空间retryTest () {//int数=retryService.retry (1); retryService.retry (1);//logger.info(“库存为:“+数); } } >之前
@Retryable不能在本类使用,不然不会生效。如果直接调用执行重试机制将不会生效,调用除号则重试生效。
公共空间执行(双,双b)抛出DevideException { 除号(a, b); } @Retryable(值=https://www.yisu.com/zixun/DevideException.class, maxAttempts=3,倒扣=@Backoff(延迟=2000 l,乘数=2)) 公共空间除号(双,双b)抛出DevideException { logger.info(“开始进行除法运算”); if (b==0) { 把新DevideException(“被除数不能为0”); } logger.info (“{}/{}={} ", a, b, a/b); } >之前使用@Retryable不能使用尝试捉捕获异常为简单
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
春天的引导使用弹簧重试重试机制的方法示例