1 场景:
1.定时发布文章
2.秒杀之后,给30分钟时间进行支付,如果30分钟后,没有支付,订单取消。
3.预约餐厅,提前半个小时发短信通知用户。
A -> 13:00 17:00 16:30 延迟时间: 7*30 * 60 * 1000
B -> 11:00 18:00 17:30 延迟时间: 13*30 * 60 * 1000
C -> 8:00 14:00 13:30 延迟时间: 11*30 * 60 * 1000
2 第一种方式:创建具有超时功能且绑定死信交换机的消息队列
@Bean
public Queue directQueueLong(){
return QueueBuilder.durable("业务队列名称")
.deadLetterExchange("死信交换机名称")
.deadLetterRoutingKey("死信队列 RoutingKey")
.ttl(20000) // 消息停留时间
//.maxLength(500)
.build();
}
监听死信队列,即可处理超时的消息队列
缺点:
上述实现方式中,ttl延时队列中所有的消息超时时间都是一样的,如果不同消息想设置不一样的超时时间,就需要建立多个不同超时时间的消息队列,比较麻烦,且不利于维护。

本文探讨了三种处理定时任务和超时情况的方法,包括使用死信队列、通用延时消息以及RabbitMQ的延时队列插件。作者详细介绍了每种方法的优缺点,并展示了如何在RabbitMQ中实现不同超时时间的消息管理。
最低0.47元/天 解锁文章
1555

被折叠的 条评论
为什么被折叠?



