当前位置: 首页 > news >正文

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. 生产者限流:根据队列状态动态控制发送速度。

http://www.lryc.cn/news/546284.html

相关文章:

  • vite-vue3使用web-worker应用指南和报错解决
  • 校园快递助手小程序毕业系统设计
  • python量化交易——金融数据管理最佳实践——使用qteasy管理本地数据源
  • BIO、NIO、AIO、Netty从简单理解到使用
  • 计算机毕业设计SpringBoot+Vue.js工厂车间管理系统源码+文档+PPT+讲解)
  • 一、图形图像的基本概念
  • 前端跨域问题初探:理解跨域及其解决方案概览
  • SQL分组问题
  • Oracle 数据库基础入门(二):深入理解表的约束
  • DeepSeek掘金——DeepSeek-R1驱动的房地产AI代理
  • WebP2P技术在嵌入式设备中的应用:EasyRTC音视频通话SDK如何实现高效通信?
  • 【零基础到精通Java合集】第三集:流程控制与数组
  • VsCode + EIDE + OpenOCD + STM32(野火DAP) 开发环境配置
  • 【vue-echarts】——01.认识echarts
  • 【http://noi.openjudge.cn/】4.3算法之图论——1538:Gopher II
  • Linux常见操作命令
  • Linux下测试Wifi性能——2.Linux下wifi指令
  • (十 九)趣学设计模式 之 中介者模式!
  • Leetcode 54: 螺旋矩阵
  • abseil-cpp:环境搭建
  • Centos7部署k8s(单master节点安装)
  • RPA 职业前景:个人职场发展的 “新机遇”
  • 详解DeepSeek模型底层原理及和ChatGPT区别点
  • 《2025年软件测试工程师面试》JAVA基础面试题
  • 【算法学习之路】5.贪心算法
  • 如何打造一个安全稳定的海外社媒账号?
  • 【Python 数据结构 5.栈】
  • Qt开发⑪Qt网络+Qt音视频_使用实操
  • JavaEE--计算机是如何工作的
  • API接口:企业名称、注册号、统一社会信用代码、企业类型、成立日期和法定代表人等数据 API 接口使用指南