#####消息成为死信的三种情况:
1.队列消息长度到达限制;
2.消费者拒接消费消息,并且不把消息重新放入原目标队列;
3.原队列存在消息过期设置,消息到达超时时间未被消费;
#####死信队列和死信交换机:
死信队列和死信交换机与正常的队列和交换机一模一样, 没有任何区别 !!
如何实现队列与死信交换机绑定 , 给队列设置如下参数:
-
x-dead-letter-exchange : 设置死信交换机
-
x-dead-letter-routing-key : 设置死信路由key
5. 延迟队列
消息进入队列后不会立即被消费,只有到达指定时间后,才会被消费。 例如:
延迟队列是一个很强大的功能 , 但是在RabbitMQ中并没有提供延迟队列功能。
可以使用:TTL(消息过期)+死信队列组合实现延迟队列的效果。
实现流程图如下 :
6. 消费端限流
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-GzZbWPgP-1651744556552)(https://upload-images.jianshu.io/uploa 《一线大厂