Rocket MQ--013--重试队列和死信队列

重试队列

正常情况下,客户端消费完消息会给MQ响应success,MQ来更新偏移量。但是万一消息处理失败了呢?应该怎么办?这个时候应该让MQ尝试以后将消息推送给我们
在这里插入图片描述
其实,一旦MQ发现一个消费者,就会为该消费者所在的组创建一个重试队列(Topic),Topic的名称为 %RETRY%消费者所在组名这点可以在控制台发现
在这里插入图片描述
如果你响应的是重试,在控制台还可以看到重试队列的消息
在这里插入图片描述

但是,MQ会重试多少次呢?默认情况下MQ会重试16次,尝试周期如下,可配置:

messageDelayLevel = 1 s 5s 10s 30s 1m 2m 3m 4m 5m 6m 7m 8m 9m 10m 20m 30m 1h 2h

尝试结束之后,如果该消息还未被消费,则会把该消息转移到死信队列

死信队列

死信队列与重试队列一样,名称为**%DLQ%消费者所在组名**,在控制台也能看到。
死信队列的默认只能写不能读,要是想消费其中的信息,必须修改权限。假如系统宕机导致消息进入了死信队列,为了消息不丢失,可以搞个消费者专门消费该队列的消息,用于补偿系统宕机期间的消息消费。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值