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

RabbitMQ延迟队列可以用于实现分布式事务。在分布式事务中,事务发起方将消息发送到消息中间件(如RabbitMQ),事务参与方从消息中间件接收消息。网络通信的不确定性可能导致分布式事务问题。为了解决这个问题,可以使用RabbitMQ延迟队列延迟队列可以通过设置消息的TTL(Time To Live)来延迟消息的投递时间。当消息的TTL过期后,消息会被发送到死信交换机(Dead Letter Exchange)。通过结合消息的TTL和死信交换机,可以实现分布式事务的延迟处理。 具体实现方法是,在事务发起方将消息发送到延迟队列时,设置消息的TTL为期望的延迟时间。当延迟时间过期后,RabbitMQ会将消息发送到死信交换机,而事务参与方可以从死信交换机接收消息并进行相应的处理。 使用RabbitMQ延迟队列实现分布式事务可以有效地减少系统内存消耗、降低数据库压力,并减小时间误差的影响。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [分布式事务(延时队列RabbitMQ)](https://blog.csdn.net/m0_55990500/article/details/127428422)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [RabbitMQ延时队列解决分布式事务问题](https://blog.csdn.net/java123456111/article/details/122925838)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值