@Retryable
@Retryable注解
被注解的方法发生异常时会重试
value:指定发生的异常进行重试
include:和value一样,默认空,当exclude也为空时,所有异常都重试
exclude:指定异常不重试,默认空,当include也为空时,所有异常都重试
maxAttemps:重试次数,默认3
backoff:重试补偿机制,默认没有
一、导入相应的包
<dependency>
<groupId>org.springframework.retry</groupId>
<artifactId>spring-retry</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-aop</artifactId>
<version>2.3.5.RELEASE</version>
</dependency>
二、开启重试机制
@SpringBootApplication
@EnableRetry
public class DemoApplication {
public static void main(String[] args) {
SpringApplication.run(DemoApplication.class, args);
}
@Bean
public ThreadPoolTaskExecutor getThreadPoolTaskExecutor() {
return new ThreadPoolTaskExecutor();
}
}
三、测试
@RestController
@Slf4j
public class RetryableController {
private Integer i = 0;
@GetMapping("/retry")
@Retryable(value = {NullPointerException.class},maxAttempts = 5 backoff = @Backoff(delay = 10L, multiplier = 1))
public String getRetry() {
log.info("retry");
if (i != 3) {
i++;
User user = null;
user.getAge();
}
return "hello Java";
}
}
启动项目,postman测试,发现控制太打印出五个retry。
注意:
1、由于retry用到了aspect增强,所有会有aspect的坑,就是方法内部调用,会使aspect增强失效,那么retry当然也会失效。
2、重试机制,不能在接口实现类里面写。所以要做重试,必须单独写个service。
3、maxAttemps参数解释的是说重试次数,但是我再打断点的时候发现这个=1时,方法一共只执行了一次。