0

0

延时任务实现方案

看不見的法師

看不見的法師

发布时间:2025-06-25 11:54:13

|

501人浏览过

|

来源于php中文网

原创

在购买火车票或订外卖时,完成订单后通常会进入支付页面,该页面设有倒计时,要求在规定时间内完成支付,否则订单将自动取消。这是一个典型的延时任务业务场景。关键在于如何在订单超时时立即触发取消订单的操作。

那么,如何实现这种延时任务呢?通常有以下四种方案:

  1. 定时任务轮询数据库(DB)

    用户下单后,数据库中会生成一条订单记录,包括订单号、用户ID、创建时间、订单详情和订单状态等信息。假设超时时间为600秒,我们可以启动一个定时任务,每隔固定时间运行一次,每次扫描数据库中的超时订单,并执行取消操作。

    select * from order where createTime < now() - interval '600 seconds'

    这种方法实现简单,但存在许多缺点。超时时间通常是秒级的,如果定时任务每秒运行一次,会对数据库资源造成巨大消耗,因此定时任务通常不会设置为秒级;然而,如果设置为分钟级,会牺牲即时性,例如,600秒的超时时间,可能在660秒后才取消订单。

  2. DelayQueue(JDK的延迟队列)

    JDK的DelayQueue是一种无界阻塞队列,只有在延迟期满时才能从中获取元素。每次生成订单时,除了将订单记录到数据库外,还需要将订单ID等信息投递到延迟队列中。队列会根据超时时间进行排序,最先超时的订单排在队列头部。启动一个独立线程,不断从队列中取出元素并执行取消订单的操作。

    这种方法的最大缺点是超时信息未持久化,服务重启后,延迟队列中的元素不会被恢复。

    mallcloud商城
    mallcloud商城

    mallcloud商城基于SpringBoot2.x、SpringCloud和SpringCloudAlibaba并采用前后端分离vue的企业级微服务敏捷开发系统架构。并引入组件化的思想实现高内聚低耦合,项目代码简洁注释丰富上手容易,适合学习和企业中使用。真正实现了基于RBAC、jwt和oauth2的无状态统一权限认证的解决方案,面向互联网设计同时适合B端和C端用户,支持CI/CD多环境部署,并提

    下载
  3. Redis的ZSet

    在Redis中创建一个名为“delayOrders”的ZSet,每个成员(member)是订单ID,分数(score)是订单的超时时间戳。我们从ZSet中取出分数最小的元素(即最先超时的订单),判断其是否已超时。如果已超时,则将其从ZSet中删除并取消订单;如果未超时,则继续下一次循环。

  4. RabbitMQ的TTL+DLX

    RabbitMQ可以设置消息的过期时间(TTL),当消息过期后,可以将其投递到队列上设置的死信交换器(DLX)上。然后,消息被投递到死信队列中,重新消费。

    延时任务实现方案

四种方案的对比如下:

方案 优点 缺点
定时任务轮询DB 实现简单,无技术难点,异常恢复,支持分布式/集群环境 影响数据库性能,时效性差
DelayQueue 实现简单,性能较好 无法异常恢复,分布式/集群实现困难
Redis的ZSet 解耦,异常恢复,扩展性强,支持分布式/集群环境 增加Redis维护,占用带宽
RabbitMQ的TTL+DLX 解耦,异常恢复,扩展性强,支持分布式/集群环境 增加RabbitMQ维护,占用带宽

来源://xiangxianzui.github.io/2020/02/延时任务实现方案

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
rabbitmq和kafka有什么区别
rabbitmq和kafka有什么区别

rabbitmq和kafka的区别:1、语言与平台;2、消息传递模型;3、可靠性;4、性能与吞吐量;5、集群与负载均衡;6、消费模型;7、用途与场景;8、社区与生态系统;9、监控与管理;10、其他特性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

206

2024.02.23

Java 消息队列与异步架构实战
Java 消息队列与异步架构实战

本专题系统讲解 Java 在消息队列与异步系统架构中的核心应用,涵盖消息队列基本原理、Kafka 与 RabbitMQ 的使用场景对比、生产者与消费者模型、消息可靠性与顺序性保障、重复消费与幂等处理,以及在高并发系统中的异步解耦设计。通过实战案例,帮助学习者掌握 使用 Java 构建高吞吐、高可靠异步消息系统的完整思路。

47

2026.01.28

什么是分布式
什么是分布式

分布式是一种计算和数据处理的方式,将计算任务或数据分散到多个计算机或节点中进行处理。本专题为大家提供分布式相关的文章、下载、课程内容,供大家免费下载体验。

404

2023.08.11

分布式和微服务的区别
分布式和微服务的区别

分布式和微服务的区别在定义和概念、设计思想、粒度和复杂性、服务边界和自治性、技术栈和部署方式等。本专题为大家提供分布式和微服务相关的文章、下载、课程内容,供大家免费下载体验。

249

2023.10.07

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

743

2023.08.10

github中文官网入口 github中文版官网网页进入
github中文官网入口 github中文版官网网页进入

github中文官网入口https://docs.github.com/zh/get-started,GitHub 是一种基于云的平台,可在其中存储、共享并与他人一起编写代码。 通过将代码存储在GitHub 上的“存储库”中,你可以: “展示或共享”你的工作。 持续“跟踪和管理”对代码的更改。

3590

2026.01.21

常用的数据库软件
常用的数据库软件

常用的数据库软件有MySQL、Oracle、SQL Server、PostgreSQL、MongoDB、Redis、Cassandra、Hadoop、Spark和Amazon DynamoDB。更多关于数据库软件的内容详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1003

2023.11.02

内存数据库有哪些
内存数据库有哪些

内存数据库有Redis、Memcached、Apache Ignite、VoltDB、TimesTen、H2 Database、Aerospike、Oracle TimesTen In-Memory Database、SAP HANA和ache Cassandra。更多关于内存数据库相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

667

2023.11.14

Rust内存安全机制与所有权模型深度实践
Rust内存安全机制与所有权模型深度实践

本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

4

2026.03.05

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 10.2万人学习

Git 教程
Git 教程

共21课时 | 4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号