前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >订单支付超时,自动关闭订单实现

订单支付超时,自动关闭订单实现

原创
作者头像
冯文议
发布2023-03-16 19:49:20
1.8K0
发布2023-03-16 19:49:20
举报
文章被收录于专栏:编程笔记

今天跟大家一起探讨一个场景:用户对商品下单,约定30分钟没支付,超时订单将被系统自动关闭。

你会如何实现呢?

早期方案:扫表

定时任务,每分钟去查询数据库,查询超时没有支付的,就修改订单状态。

扫表实现
扫表实现

思路清晰,实现起来也比较简单,但是遇到的问题也比较多,比如:

  1. 每分钟都去查询数据库,数据库的压力比较大。
  2. 有一定的延迟。

方案升级:消息队列

用户下单成功,就发送到消息队列。时间到了,消费端拿到数据,就查询数据,判断订单状态,如果没有支付,就修改订单状态。

消息队列实现
消息队列实现

目前落地的是采用 RabbitMQ 的延迟队列。用户创建订单成功,就加入到 MQ 的延迟队列,时间到了,就会自动消费,然后关单。

关于 RabbitMQ 延迟队列,可以看这篇文章:Spring Boot and RabbitMQ 初探 中关于【延迟队列】部分!


原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 早期方案:扫表
  • 方案升级:消息队列
相关产品与服务
消息队列
腾讯云消息队列 TDMQ 是分布式架构中的重要组件,提供异步通信的基础能力,通过应用解耦降低系统复杂度,提升系统可用性和可扩展性。TDMQ 产品系列提供丰富的产品形态,包含 CKafka、RocketMQ、RabbitMQ、Pulsar、CMQ 五大产品,覆盖在线和离线场景,满足金融、互联网、教育、物流、能源等不同行业和场景的需求。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档