@Retryable

@Retryable

@Retryable注解

被注解的方法发生异常时会重试
value:指定发生的异常进行重试
include:和value一样,默认空,当exclude也为空时,所有异常都重试
exclude:指定异常不重试,默认空,当include也为空时,所有异常都重试
maxAttemps:重试次数,默认3
backoff:重试补偿机制,默认没有

一、导入相应的包

<dependency>
  <groupId>org.springframework.retrygroupId>
  <artifactId>spring-retryartifactId>
dependency>

<dependency>
  <groupId>org.springframework.bootgroupId>
  <artifactId>spring-boot-starter-aopartifactId>
  <version>2.3.5.RELEASEversion>
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时,方法一共只执行了一次。

你可能感兴趣的:(Spring,Boot,Spring,java,spring,spring,boot)