RabbitMQ怎么实现延时支付?

一、使用"死信队列"+消息过期时间

1、原理:

设置消息"存活时间",如果没有被及时消费,就会被丢弃到一个"死信队列",然后消费者监听这个死信队列处理消息

2、步骤:

2.1、创建两个队列:

2.1.1、普通队列:设置过期时间(30分钟),并指定过期后转到死信队列
2.1.2、死信队列:消费者监听这里处理超时订单。

2.2、用户下单,发送一条消息到普通队列,这条消息30分钟后自动过期,进入死信队列。

args.put("x-dead-letter-exchange", "dead_exchange");

2.3、消费者从死信队列拿到消息,检查支付状态,取消未支付订单

3、优缺点:

3.1、优点:不用装插件,纯RabbitMQ自带功能

3.2、缺点:如果消息还没过期就被消费了,可能会提前触发(需要保证普通队列没人消费)

二、用Rabbit MQ官方插件(延时消息插件)

1、原理:

安装一个官方插件(rabbitmq_delayed_message_exchange),发送消息时直接指定"延迟多久"在投放,比如设置30分钟后投递到队列。

2、步骤:

2.1、安装插件,创建一个特殊类型的交换机(x-delayed-message类型)

2.2、发送消息时带上参数:headers.put("x-delay",30*60*1000)。表示延时30分钟。

2.3、消费者正常监听队列,30分钟后才会接收消息去处理

3、优缺点:

3.1、优点:简单直接,消息精准延时。

3.2、需要装插件,运维成本更高。

问题:消息阻塞问题?

  1. 加消费者:最简单的办法,多开几个实例一起消费。

  2. 调预取值:控制每个消费者拿消息的数量,别让它"贪多嚼不烂"。

  3. 设队列上限:队列不能无限扩容,超过长度直接拒绝或丢旧消息。

  4. 设消息过期:没用的消息早点扔掉,比如超时未支付的订单。

  5. 死信队列兜底:过期或失败的消息统一转到一个队列处理。

  6. 监控告警:发现队列快满了,赶紧扩容或限流。

  7. 生产者限流:根据队列状态动态控制发送速度。

相关推荐
qq_1249870753几秒前
基于JavaWeb的大学生房屋租赁系统(源码+论文+部署+安装)
java·数据库·人工智能·spring boot·计算机视觉·毕业设计·计算机毕业设计
短剑重铸之日6 分钟前
《设计模式》第十一篇:总结
java·后端·设计模式·总结
User_芊芊君子27 分钟前
【分布式训练】CANN SHMEM跨设备内存通信库:构建高效多机多卡训练的关键组件
分布式·深度学习·神经网络·wpf
若鱼191929 分钟前
SpringBoot4.0新特性-Observability让生产环境更易于观测
java·spring
觉醒大王38 分钟前
强女思维:着急,是贪欲外显的相。
java·论文阅读·笔记·深度学习·学习·自然语言处理·学习方法
努力学编程呀(๑•ี_เ•ี๑)1 小时前
【在 IntelliJ IDEA 中切换项目 JDK 版本】
java·开发语言·intellij-idea
酷酷的崽7981 小时前
CANN 开源生态解析(四):`cann-dist-train` —— 构建高效可扩展的分布式训练引擎
分布式·开源
码农小卡拉1 小时前
深入解析Spring Boot文件加载顺序与加载方式
java·数据库·spring boot
向上的车轮1 小时前
为什么.NET(C#)转 Java 开发时常常在“吐槽”Java:checked exception
java·c#·.net
Dragon Wu1 小时前
Spring Security Oauth2.1 授权码模式实现前后端分离的方案
java·spring boot·后端·spring cloud·springboot·springcloud