Spring boot使用spring retry重试机制的方法示例
2020-03-19 12:07
513 查看
当我们调用接口的时候由于网络原因可能失败,再尝试就成功了,这就是重试机制。非幂等的情况下要小心使用重试。
tips:幂等性
HTTP/1.1中对幂等性的定义是:一次和多次请求某一个资源对于资源本身应该具有同样的结果(网络超时等问题除外)。也就是说,其任意多次执行对资源本身所产生的影响均与一次执行的影响相同。
注解方式使用Spring Retry
(一)Maven依赖
<!-- 重试机制 --> <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一样,默认为空,当exclude也为空时,默认所以异常
exclude:指定不处理的异常
maxAttempts:最大重试次数,默认3次
backoff:重试等待策略,默认使用@Backoff,@Backoff的value默认为1000L;multiplier(指定延迟倍数)
@Recover注解:
当重试达到指定次数时候该注解的方法将被回调
发生的异常类型需要和@Recover注解的参数一致
@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("开始进行除法运算"); if (b == 0) { throw new RuntimeException(); } logger.info("{} / {} = {}", a, b, a / b); } @Recover public void recover() { logger.error("被除数不能为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); } }
注意事项
@Retryable不能在本类使用,不然不会生效。如果直接调用execute重试机制将不会生效,调用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("开始进行除法运算"); if (b == 0) { throw new DevideException("被除数不能为0"); } logger.info("{} / {} = {}", a, b, a / b); }
使用@Retryable不能使用try catch捕获异常为简单
以上就是本文的全部内容,希望对大家的学习有所帮助
您可能感兴趣的文章:
相关文章推荐
- Spring boot使用spring retry重试机制
- 使用Docker部署Spring Boot的方法示例
- Spring Boot使用AOP防止重复提交的方法示例
- window.scrollBy()方法使用示例
- SAFEARRAY使用方法示例
- 使用JAVA的反射机制反射带有数组参数的私有方法
- window.scrollTo()方法使用示例
- Asp.net 2.0 自定义控件开发专题[详细探讨页面状态(视图状态和控件状态)机制及其使用场景](示例代码下载)
- JavaScript split()使用方法与示例
- Lua5.1的元方法__call的使用示例
- 深度解析ASP.NET2.0中的Callback机制callback的一般使用方法还算简单,直接参照
- window.scrollBy()方法使用示例
- Asp.net 2.0 自定义控件开发专题[详细探讨页面状态(视图状态和控件状态)机制及其使用场景](示例代码下载)
- 使用.Net Reflection 反射机制 动态获取对象字段内容的示例
- 邮件发送控件jmail使用方法之ASP.NET示例
- Android的消息机制,用Android线程间通信的Message机制,Android中Handler的使用方法——在子线程中更新界面,handler机制
- Android的消息机制,用Android线程间通信的Message机制,Android中Handler的使用方法——在子线程中更新界面,handler机制
- Android中的.9.png图形的机制及制作和使用方法
- 方法的使用示例
- windows.moveBy()函数使用方法示例