场景:
很多时候,我们在调用其他三方服务的时候,由于网络抖动,网络延迟,导致网络超时等其他网络异常,常见的支付场景,
这中情况下就需要有重试机制,并且重试次数成阶梯式,就像微信的支付重试,重试在MQ的实现中也很常见。
spring提供了spring-retry 模块,最初在spring-batch,2.2版本后独立出来了
1,引入依赖
<dependency>
<groupId>org.springframework.retry</groupId>
<artifactId>spring-retry</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.aspectj</groupId>
<artifactId>aspectjweaver</artifactId>
</dependency>
这个功能是基于注解开发的,所以依赖aspectjweaver。
2,入口开启EnableRetry 功能拦截
3,service 需要重试的方法加上@Retryable ,只要抛出异常(这里用一个Exception接管所有的异常)就可以开始重试
value = Exception.class, 遇到重试异常的
maxAttempts = 5,//重试的次数
backoff =@Backoff(
delay = 2000L,// 延迟秒数
multiplier = 2)//指定延迟倍数
4,重试次数耗尽执行方法
原文参考:https://juejin.im/post/5af2b2075188256720340d31
相关文章:https://blog.csdn.net/zzzgd_666/article/details/84377962