死信队列,英文缩写:DLX 。Dead Letter Exchange(死信交换机),当消息成为Dead message (死信)后,可以被重新发送到另一个交换机,这个交换机就是DLX。
#####消息成为死信的三种情况:
1.队列消息长度到达限制;
2.消费者拒接消费消息,并且不把消息重新放入原目标队列;
3.原队列存在消息过期设置,消息到达超时时间未被消费;
#####死信队列和死信交换机:
死信队列和死信交换机与正常的队列和交换机一模一样, 没有任何区别 !!
如何实现队列与死信交换机绑定 , 给队列设置如下参数:
-
x-dead-letter-exchange : 设置死信交换机
-
x-dead-letter-routing-key : 设置死信路由key
5. 延迟队列
消息进入队列后不会立即被消费,只有到达指定时间后,才会被消费。 例如:
延迟队列是一个很强大的功能 , 但是在RabbitMQ中并没有提供延迟队列功能。
可以使用:TTL(消息过期)+死信队列组合实现延迟队列的效果。
实现流程图如下 :