目录
重试次数超过设置的最大次数时还是失败则执行回调@Recover
背景
对接抖音小玩法时,需要调用抖音的接口开启直播间数据推送任务;
若是调用接口时失败则不能进行后续的业务逻辑处理;
所以在第三方平台调用时需要引入失败重试机制
引入依赖
<dependency>
<groupId>org.springframework.retry</groupId>
<artifactId>spring-retry</artifactId>
</dependency>
开启重试
/**
* 启动类上面添加@EnableRetry注解,启用重试功能,
* 或者在使用retry的service上面添加也可以,在Configuration类上面也没毛病。
*/
// 在配置类
@Slf4j
@Configuration
@EnableRetry
public class CacheConfig{
}
// 启动类
@SpringBootApplication
@EnableRetry
public class Application{
}
在需要重试的方法上加上注解@Retryable
- value值表示当哪些异常的时候触发重试
- maxAttempts最大重试次数 默认三次
- delay表示重试的延迟时间
- multiplier表示上一次延时时间是这一次的倍数
@Retryable(value = Exception.class,maxAttempts = 3,backoff = @Backoff(delay = 2000,multiplier = 1.5))
public void testRetry() throws Exception {
System.out.println("==========开始执行========="+new Date().getTime());
if (1==1) {
String str = "wobenshanliang";
// 产生异常异常
Integer integer = Integer.valueOf(str);
}
System.out.println("=======执行成功=======");
}
重试次数超过设置的最大次数时还是失败则执行回调@Recover
- 回调函数需要和重试方法在一个类中
- 同个类中多个重试方法 只需要有一个回调函数(根据实际业务调整
@Recover
public void testRecover(Exception e){
System.out.println("=======重试次数到达最大值,重试结束===="+e.getMessage());
}
执行结果
===============开始执行===================1606274378617 ===============开始执行===================1606274380618 ===============开始执行===================1606274383618 =============重试次数到达最大值,重试结束=========For input string: "wobenshanliang"
踩坑提示
由于retry用到了aspect增强,所有会有aspect的坑,就是方法内部调用,会使aspect增强失效,那么retry当然也会失效;
public class demo {
public void A() {
B();
}
//这里B不会执行
@Retryable(Exception.class)
public void B() {
throw new RuntimeException("retry...");
}
}
重试机制,不能在接口实现类里面写。所以要做重试,必须单独写个service。
maxAttemps参数解释的是说重试次数,但是我再打断点的时候发现这个=1时,方法一共只执行了一次。