一 死信队列的定义
死信,在官网中对应的单词为“Dead Letter”
“死信”是RabbitMQ中的一种消息机制,当你在消费消息时,如果队列里的消息出现以下情况:
- 消息被否定确认,使用channel.BasicNack或 channel.BasicReject,并且此时
requeue
属性被设置为false
。 - 消息在队列的存活时间超过设置的TTL时间。
- 消息队列的消息数量已经超过最大队列长度。
那么该消息将成为“死信”。
“死信”消息会被RabbitMQ进行特殊处理,如果配置了死信队列信息,那么该消息将会被丢进死信队列中,如果没有配置,则该消息将会被丢弃。
二 死信队列的生命周期
1.业务消息被投入业务队列
2.消费者消费业务队列的消息,由于处理过程中发生异常,于是进行了nack或者reject操作
3.被nack或者reject的消息由RabbitMQ投递到死信交换机中
4.死信交换机将消息投入到对应的死信队列
5.死信队列的消费者消费死信消息
三 死信队列的总结
死信队列并不是什么特殊的队列,只不过是绑定在死信交换机上的队列。死信交换机也不是什么特殊的交换机,只不过是用来接受死信的交换机,所以可以为任何类型【Direct、Fanout、Topic】。一般来说,会为每个业务队列分配一个独有的路由key,并对应的配置一个死信队列进行监听,也就是说,一般会为每个重要的业务队列配置一个死信队列。