008 rabbitmq延迟队列实现

前言:通过设置队列的过期时间和死信交换器来实现。当队列内的消息达到设置的时间,将由死信交换器通过死信路由,发送到死信交换器绑定的队列上进行消费。

使用场景举例:买家下订单之后,在未规定时间内进行支付,需要释放订单资源。可在下单时,推送到orderTtl订单ttl队列,当达到规定时间后,消息由orderTtl转移到orderDelay订单延迟队列,交由orderDelay订单延迟队列的消费者进行未付款的资源释放处理。

1、设置队列;

2、设置交换器;

3、定义orderTtl生产者;

4、定义orderDelay消费者;

5、分析;

orderTtl生产者的消息最先是发送到了order.ttl队列。当超过1000*10秒后,消息被转移到了order.delay队列,进而被orderDelay消费者消费掉。

6、测试;

7、结果如下,符合预期;

8、demo地址;

https://github.com/haishui211/rabbitmqRep.git

猜你喜欢

转载自blog.csdn.net/haishui2/article/details/82627441
008