美文网首页springboot工作总结J2EE
springboot 整合retry(重试机制)

springboot 整合retry(重试机制)

作者: 二月_春风 | 来源:发表于2017-07-24 21:57 被阅读1865次

当我们调用一个接口可能由于网络等原因造成第一次失败,再去尝试就成功了,这就是重试机制,spring支持重试机制,并且在Spring Cloud中可以与Hystaix结合使用,可以避免访问到已经不正常的实例。

写一个简单的demo,加入依赖:

<dependencies>
    <dependency>
         <groupId>org.springframework.boot</groupId>
         <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <dependency>
         <groupId>org.springframework.retry</groupId>
         <artifactId>spring-retry</artifactId>
     </dependency>
     <dependency>
          <groupId>org.aspectj</groupId>
          <artifactId>aspectjweaver</artifactId>
     </dependency>
</dependencies>

在主类上加上@EnableRetry注解,表示启用重试机制。

@SpringBootApplication
@EnableRetry
public class Application {
    public static void main(String[] args) {
        SpringApplication.run(Application.class,args);
    }
}

定义一个简单的controller层:

@RestController
public class HelloController {

    Logger logger = LoggerFactory.getLogger(getClass());

    @Autowired
    private PayService payService;

    @GetMapping("/createOrder")
    public String createOrder(@RequestParam int num) throws Exception{
        int remainingnum = payService.minGoodsnum(num == 0 ? 1: num);
        logger.info("剩余的数量==="+remainingnum);
        return "库库存成功";
    }

}

在controller中调用减库存的service接口,

@Service
public class PayService {

    private Logger logger = LoggerFactory.getLogger(getClass());

    private final int totalNum = 100000;


    @Retryable(value = Exception.class,maxAttempts = 3,backoff = @Backoff(delay = 2000,multiplier = 1.5))
    public int minGoodsnum(int num) throws Exception{
        logger.info("minGoodsnum开始"+ LocalTime.now());
        if(num <= 0){
            throw new Exception("数量不对");
        }
        logger.info("minGoodsnum执行结束");
        return totalNum - num;
    }
}

在minGoodsnum方法上加上@Retryable注解,value值表示当哪些异常的时候触发重试,maxAttempts表示最大重试次数默认为3,delay表示重试的延迟时间,multiplier表示上一次延时时间是这一次的倍数。

测试:

图片.png 图片.png

重试三次抛出异常。

使用@Recover注解,当重试次数达到设置的次数的时候,还是失败抛出异常,执行的回调函数。

关于@Recover注解

图片.png

和minGoodsnum定义在一个类中

@Recover
public int recover(Exception e){
        logger.warn("减库存失败!!!");
        //记日志到数据库
        return totalNum;
}

重试测试一下,

图片.png

感觉意义不大,重试失败的时候应该还是要抛出异常的,在上层进行catch记录日志,当然也有特殊的场景适用。

相关文章

  • springboot 整合retry(重试机制)

    当我们调用一个接口可能由于网络等原因造成第一次失败,再去尝试就成功了,这就是重试机制,spring支持重试机制,并...

  • 说一说java的重试机制的另一种实现

    一、重试机制的几种实现 guava retry spring retry for/while循环+sleep 对重...

  • SpringBoot 中使用Spring retry 重试机制

    在日常开发中重试机制还是比较常用的,比如因网络原因等引起的超时,必要的重试市必须的。那么在springboot中如...

  • Spring Retry重试机制

    在调用第三方接口或者使用mq时,会出现网络抖动,连接超时等网络异常,所以需要重试。为了使处理更加健壮并且不太容易出...

  • Spring Retry重试机制

    在调用第三方接口或者使用mq时,会出现网络抖动,连接超时等网络异常,所以需要重试。为了使处理更加健壮并且不太容易出...

  • SpringRetry重试机制

    Spring boot使用spring retry重试机制 当我们调用接口的时候由于网络原因可能失败,再尝试就成功...

  • SpringBoot——异常重试Spring-Retry

    前言 spring retry是从spring batch独立出来的一个能功能,主要实现了重试和熔断。对于重试是有...

  • 重试机制(一):Guava Retry

    项目中经常会遇到需要重试的场景,例如读取数据库,调用远程api等。可以自己来实现重试策略,但是不用重复造轮子,有很...

  • http retry

    Retrying http 请求时候的retry, 当失败时候需要进行重试。而 在python中有 retry 库...

  • Spring重试之Spring-Retry和Guava-Retr

    1 重试之Spring-Retry 1.1 直接使用 Spring Retry 为 Spring 应用程序提供了声...

网友评论

  • 小小鱼_503b:引入了上节“Springboot事件监听”中的 @EventListener
    public void event(Object event){
    System.out.println("MyEventHandle 接收到事件:" + event.getClass());
    }
    后,抛出异常的时候为什么打印了2次“MyEventHandle 接收到事件:class org.springframework.web.context.support.ServletRequestHandledEvent”,没抛异常只打印1次。

本文标题:springboot 整合retry(重试机制)

本文链接:https://www.haomeiwen.com/subject/aysekxtx.html