SpringBoot 整合 retry

当我们调用一个接口可能由于网络等原因造成第一次失败,再去尝试就成功了,这就是重试机制,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表示上一次延时时间是这一次的倍数。

测试:

 

 

 

 

重试三次抛出异常。

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

关于@Recover注解

 

和minGoodsnum定义在一个类中

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

重试测试一下,

 

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你好,关于rabbitmq整合springboot实现延迟队列的具体代码实现,可以参考以下步骤: 1. 在pom.xml文件中添加以下依赖: ``` <dependency> <groupId>org.springframework.amqp</groupId> <artifactId>spring-rabbit</artifactId> <version>2.2.10.RELEASE</version> </dependency> ``` 2. 在application.yml文件中添加以下配置: ``` spring: rabbitmq: host: localhost port: 5672 username: guest password: guest virtual-host: / listener: simple: acknowledge-mode: manual retry: enabled: true initial-interval: 100 max-attempts: 3 multiplier: 2 max-interval: 10000 template: exchange: delay_exchange routing-key: delay_queue default-receive-queue: delay_queue message: converter: json ``` 3. 创建延迟队列和交换机 ``` @Configuration public class RabbitConfig { @Bean public Queue delayQueue() { Map<String, Object> args = new HashMap<>(); args.put("x-dead-letter-exchange", "delay_exchange"); args.put("x-dead-letter-routing-key", "delay_queue"); return new Queue("delay_queue", true, false, false, args); } @Bean public DirectExchange delayExchange() { return new DirectExchange("delay_exchange"); } @Bean public Binding delayBinding() { return BindingBuilder.bind(delayQueue()).to(delayExchange()).with("delay_queue"); } } ``` 4. 创建消息发送者 ``` @Service public class DelaySender { @Autowired private RabbitTemplate rabbitTemplate; public void sendDelayMessage(String message, long delayTime) { rabbitTemplate.convertAndSend("delay_exchange", "delay_queue", message, new MessagePostProcessor() { @Override public Message postProcessMessage(Message message) throws AmqpException { message.getMessageProperties().setExpiration(String.valueOf(delayTime)); return message; } }); } } ``` 5. 创建消息消费者 ``` @Component @RabbitListener(queues = "delay_queue") public class DelayReceiver { @RabbitHandler public void process(String message) { System.out.println("Received message: " + message); } } ``` 以上就是rabbitmq整合springboot实现延迟队列的具体代码实现,希望能对你有所帮助。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值