【设计】springboot rabbitmq重试达到失败次数 进入死信队列

 

代码示例:

复制代码
@Slf4j
@Service
@RabbitListener(queues = {"${spring.events.[event.product.product_price_changed].queue}"}, concurrency = "1", containerFactory = "rabbitListenerContainerFactory")
public class ProductPriceChangeEventHandlerBak {

    @Async
    @RabbitHandler
    @Retryable(include = Exception.class, maxAttempts = 3, backoff = @Backoff(delay = 5000, multiplier = 2, maxDelay = 60000))
    public void onProductPriceChange(ProductPriceChangeEvent event, Channel channel, Message message) throws Exception {
        log.info("handle event start: {}", event);
        long deliveryTag = message.getMessageProperties().getDeliveryTag();

        TimeUnit.SECONDS.sleep(5);
        if (event.getPriceNew().equals(new BigDecimal("808.88"))) {
            throw new CommonException(ErrorCode.INTERNAL_ERROR);
        }
        channel.basicAck(deliveryTag, false);

        log.info("handle event complete: success");
    }

    @Recover
    public void onProductPriceChange(Exception ex, ProductPriceChangeEvent event, Channel channel, Message message) throws Exception {
        long deliveryTag = message.getMessageProperties().getDeliveryTag();
        channel.basicNack(deliveryTag, false, false);
        log.error("handle event complete: exception");
    }
}
复制代码

 

posted @   junneyang  阅读(369)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 字符编码:从基础到乱码解决
历史上的今天:
2020-06-20 数据仓库、数据湖、流批一体,终于有大神讲清楚了!
2016-06-20 【消息队列】转-大型网站架构之分布式消息队列
点击右上角即可分享
微信分享提示