RabbitMQ学习-死信队列

一 死信队列的定义

死信,在官网中对应的单词为“Dead Letter”

“死信”是RabbitMQ中的一种消息机制,当你在消费消息时,如果队列里的消息出现以下情况:

  1. 消息被否定确认,使用channel.BasicNack或 channel.BasicReject,并且此时requeue 属性被设置为false
  2. 消息在队列的存活时间超过设置的TTL时间。
  3. 消息队列的消息数量已经超过最大队列长度。

那么该消息将成为“死信”。

“死信”消息会被RabbitMQ进行特殊处理,如果配置了死信队列信息,那么该消息将会被丢进死信队列中,如果没有配置,则该消息将会被丢弃。

二 死信队列的生命周期

1.业务消息被投入业务队列

2.消费者消费业务队列的消息,由于处理过程中发生异常,于是进行了nack或者reject操作

3.被nack或者reject的消息由RabbitMQ投递到死信交换机中

4.死信交换机将消息投入到对应的死信队列

5.死信队列的消费者消费死信消息

三 死信队列的总结

       死信队列并不是什么特殊的队列,只不过是绑定在死信交换机上的队列。死信交换机也不是什么特殊的交换机,只不过是用来接受死信的交换机,所以可以为任何类型【Direct、Fanout、Topic】。一般来说,会为每个业务队列分配一个独有的路由key,并对应的配置一个死信队列进行监听,也就是说,一般会为每个重要的业务队列配置一个死信队列。

 

参考链接:https://www.cnblogs.com/mfrank/p/11184929.html

上一篇:【RabbitMQ】安装RabbitMQ(二)


下一篇:java代码学习(九) ——RMI