延时队列
延时队列.队列内部是有序的,最重要的特性就体现在它的延时属性上,延时队列中的元素是希望在指定时间到了以后或之前取出和处理,简单来说, 延时队列就是用来存放需要在指定时间被处理的元素的队列, 延时队列其实就是特殊的死信队列
基于死信队列存在的问题:
如果在消息属性上设置TTL的方式,消息可能并不会按时"死亡",因为RabbitMQ只会检查第一个消息是否过期,如果过期则丢到死信队列,如果第一个消息的延时时长很长, 而第二个消息的延时时长很短,第二个消息并不会优先得到执行,而是在第一个消息过期后才会执行
死信队列应用场景
为保证订单业务消息数据不丢失,需要使用到RabbitMQ的死信队列机制,当消息消费发生异常时,将消息投入死信队列中,还比如说:用户在商城下单成功并点击去支付后在指定时间内未支付时自动失效
特点
由于某些特定的原因导致queue中的某些消息无法被消费
死信的来源
消息TTL过期
队列达到最大长度
消息被拒绝(basic.reject或basic.nack)并且requeue-false
死信的设置
//正常队列设置死信交换机
arguments.