0
点赞
收藏
分享

微信扫一扫

《RabbitMQ系列教程-第十章-RabbitMQ之延时队列》


教程说明

  • 本系列教程目录大纲:​​《RabbitMQ系列教程-目录大纲》​​
  • 本系列教程配套代码:​​https://gitee.com/Horizon1024/rabbitmt.git​​(码云地址)

RabbitMQ之延时队列

有时候我们希望消息到达之后不会被立即消费,而是等到指定的时间进行消费,这个时候我们就可以利用延时队列来完成我们的功能

延时队列的应用场景:

1)下一个订单,如果10分钟后还未支付,那么修改其订单状态

2)当用户3天未登录,进行登录提醒、礼包赠送等

3)开启一个会议后,会议达到开始时间时自动更改状态

在​​RabbitMQ​​中,我们可以借助TTL+死信队列来完成延时队列的效果

延时队列很大程度上解决了我们以前定时器的功能,定时器通常采用每秒、每分钟轮询方式进行,这样不仅效率低,对数据库压力也非常大,代码不够严谨美观;

延时队列工作流程图:

《RabbitMQ系列教程-第十章-RabbitMQ之延时队列》_rabbitmq

当一个​​Producer​​发送出一个消息之后,设置过期时间并推送到指定的业务队列中(或业务交换机),超过指定的时间不消费,该消息自动成为死信,并交由死信交换机分发给死信队列,消费者只要监听死信队列中的消息即可;

上述案例中Producer直接将消息发送给Queue,也可以发送给业务交换机,然后由业务交换机转发给Queue

7.4.2 案例测试

配置spring.xml:

<!--配置业务队列-->
<rabbit:queue name="test_queue_dlx2" id="test_queue_dlx2">
<rabbit:queue-arguments>
<!--3.1 x-dead-letter-exchange:死信交换机名称-->
<entry key="x-dead-letter-exchange" value="exchange_dlx"/>

<!--3.2 x-dead-letter-routing-key:发送给死信交换机的routingKey-->
<entry key="x-dead-letter-routing-key" value="dlx.abc"/>
</rabbit:queue-arguments>
</rabbit:queue>

测试类:

/**
* 延迟队列
* TTL+死信队列
*/
@Test
public void testDelay() {
//1. 测试过期时间,死信消息
MessageProperties prop = new MessageProperties();
// 5s不消费消息将成为死信
prop.setExpiration("5000");

Message message = new Message("delay=ttl+dl".getBytes(), prop);

rabbitTemplate.convertAndSend("test_queue_dlx2", message);
}

测试观察,发送消息到test_queue_dlx2(正常的队列)中,5s没有消费该消息自动到死信队列中;


举报

相关推荐

0 条评论