定时任务概述

本文涉及的产品
RDS DuckDB + QuickBI 企业套餐,8核32GB + QuickBI 专业版
简介: 定时任务是按时间表达式调度执行的任务,适用于对账、提醒、订单超时处理等场景。单体方案包括轮询休眠、Timer、ScheduledExecutorService、Quartz和SpringTask;分布式场景则需解决重复执行、动态调整、故障转移等问题,主流方案有XXL-JOB、Elastic-Job、Saturn等。(239字)

什么是定时任务

通过时间表达式来进行调度和执行的一类任务被称为定时任务。一般能解决的业务场景:定时对账、服务到期的定时提醒、订单超时未支付的自动取消等。

有哪些定时任务实现方案

单体架构调度技术

  • 轮询+线程休眠

while(true) + Thread.sleep

  • java.util.Timer + java.util.TimerTask

Timer是一个定时器工具,用来在一个后台线程计划执行指定任务,它可以计划执行一个任务或反复多次

TimerTask是一个抽象类,它的子类代表一个可以被Timer计划执行的任务

  • ScheduledExecutorService

JDK1.5之后作为并发工具被引入,默认只支持周期性的执行频率(如每秒/每分钟),要支持具体某一刻年月日时分秒的执行窗口需要自定义扩展,较麻烦

  • Quartz

开源任务调度框架,Java语言编写实现,支持Spring整合使用

  • SpringTask

spring框架提供的轻量级定时任务调用工具

SpringBoot框架下可使用注解:@EnableScheduling+@Scheduled,底层还是SpringTask

分布式架构调度技术

分布式场景可能遇到的问题

  • 多台机器集群部署的定时任务如何保证不被重复执行
  • 如果在不重启服务前提下,动态调整定时任务执行时间
  • 部署定时任务的机器发生故障如何故障转移
  • 如何对定时任务做任务监控

业界解决方案

  • 淘宝:TBSchedule,现在是:ScheduleX
  • 当当:Elastic-Job
  • 唯品会:Saturn,基于当当的二次开发,新增一些特性
  • 大众点评:XXL-JOB
目录
相关文章
|
2月前
|
人工智能 Linux API
阿里云+本地三系统部署 OpenClaw 及精准参数调优手册:千问/Coding Plan模型对接教程
在日常使用OpenClaw(原Clawdbot)的过程中,很多用户都会遇到输出随机、答非所问、重复啰嗦、长度失控等问题,这些并非模型能力不足,而是**温度、最大生成长度、采样参数、惩罚系数**没有匹配场景。与此同时,正确完成云端与本地部署、对接稳定大模型,是让AI稳定输出的前提。
779 17
|
9天前
|
弹性计算 数据可视化
阿里云服务器管理控制台(后台)在哪登录?统一阿里云后台链接入口整理,一键直达
阿里云服务器管理控制台是ECS与轻量应用服务器的统一可视化后台,支持重启、远程连接、重装系统等操作。主入口为控制台首页(home.console.aliyun.com),亦可直连ECS官网:https://t.aliyun.com/U/AZBUsA 或轻量官网:https://t.aliyun.com/U/dwftch
258 8
|
2月前
|
人工智能 机器人 API
零基础阿里云轻量服务器部署OpenClaw接入企业微信:AI助手搭建与避坑指南
通过阿里云轻量服务器部署OpenClaw并接入企业微信,可快速打造专属AI办公助手,实现消息响应、系统控制、文本生成、定时任务等功能。本文从零基础部署到避坑指南,覆盖全流程,所有代码可直接复制执行,新手也能轻松上手。需注意安全风险,保护企业微信应用Secret和API-Key,遵守相关规定,合理使用AI工具提升办公效率。
552 10
|
2月前
|
存储 缓存 安全
缓存是黑客最爱渗透和攻击的一环。为什么?优雅草卓伊凡
缓存虽提升性能,却成黑客攻击重灾区:缓存中毒、投毒、穿透、时间戳攻击及泄露等手段频发,易致数据泄露、页面篡改、服务瘫痪。因其配置常被忽视、应用广泛、防御薄弱,亟需强化策略配置、输入验证、缓存隔离与HTTPS加密防护。(239字)
154 10
|
2月前
|
运维 API 调度
阿里云/本地部署OpenClaw多Agent架构完全指南:Multi‑Agent与主Agent+Sub‑Agent选型、大模型配置流程
在OpenClaw的实际使用中,用户最容易陷入架构困惑:到底应该使用**Multi‑Agent(多独立智能体)**,还是**主Agent + Sub‑Agent(总控+子代理)**?两种模式在设计目标、运行机制、数据隔离、权限管理、消息路由上完全不同,混用会导致上下文混乱、维护成本飙升、系统不稳定。
2000 16
|
2天前
|
uml C语言
系统时序图
时序图(Sequence Diagram)是UML交互图,用以动态展示对象间按时间顺序的消息传递与协作。横轴为对象,纵轴为时间,核心元素包括角色、对象、生命线、控制焦点及同步/异步消息等,广泛用于建模系统行为与并发流程。(239字)
62 3
 系统时序图
|
2月前
|
缓存 NoSQL 关系型数据库
4-Redis篇-3
Redis与Memcached在数据结构、集群支持及持久化上差异显著;内存满时Redis可淘汰或报错;与MySQL一致性可通过删缓存+双写、MQ异步、过期策略等方案分级保障;缓存穿透用布隆过滤器,击穿靠预热、永不过期或加锁限流。(239字)
|
2天前
|
存储 安全 芯片
【2026最新】U盘检测工具MyDiskTest安装使用教程(附安装包+图文步骤)
MyDiskTest是一款轻量免安装的Windows U盘/存储卡检测工具,专治“扩容盘”(虚标容量假盘),支持快速扩容检测、文件对比验证、读写速度测试及芯片真伪识别。纯中文界面,解压即用,操作简单,买新盘后验货首选。