重试队列
正常情况下,客户端消费完消息会给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%消费者所在组名**,在控制台也能看到。
死信队列的默认只能写不能读,要是想消费其中的信息,必须修改权限。假如系统宕机导致消息进入了死信队列,为了消息不丢失,可以搞个消费者专门消费该队列的消息,用于补偿系统宕机期间的消息消费。