java重试机制 springBoot+spring-retry
1.MAVEN依赖
<!--重试-->
<dependency>
<groupId>org.springframework.retry</groupId>
<artifactId>spring-retry</artifactId>
</dependency>
2.启动类添加@EnableRetry注解,表示开启重试机制
@SpringBootApplication
@EnableRetry
public class AdminApplication extends SpringBootServletInitializer {
public static void main(String[] args) {
SpringApplication.run(AdminApplication.class, args);
}
@Override
protected SpringApplicationBuilder configure(SpringApplicationBuilder application) {
return application.sources(AdminApplication.class);
}
}
3.给需要重试的方法添加重试注解@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("=======执行成功=======");
}
4.当重试次数达到设置的最大次数的时候,还是失败抛出异常,执行的回调函数
- 回调函数需要和重试方法在一个类中
@Recover
public void testRecover(Exception e){
System.out.println("=======重试次数到达最大值,重试结束===="+e.getMessage());
}
5.执行结果
===============开始执行===================1606274378617
===============开始执行===================1606274380618
===============开始执行===================1606274383618
=============重试次数到达最大值,重试结束=========For input string: "wobenshanliang"