Redian新闻
>
实现定时任务的六种策略

实现定时任务的六种策略

公众号新闻

这篇文章,我们聊聊实现定时任务的六种策略。

1 自定义单线程

上图中,我们启动一个线程,该线程无限循环执行,每隔20毫秒执行业务代码。

这种方式非常简单易用,在很多中间件中得到广泛应用。

2 JDK ScheduledExecutorService

ScheduledExecutorService 是 Java 标准库提供的一个用于调度定时任务的接口。它提供了一种相对简单的方式来执行定时任务,不需要引入额外的库。

在上述例子中:

  1. 创建了一个ScheduledExecutorService 实例,它使用了一个线程池,其中包含一个线程用于执行定时任务。
  2. 定义了一个简单的Runnable任务,输出当前时间。
  3. 使用scheduleAtFixedRate方法安排任务,指定了任务的启动延迟时间和执行间隔时间。
  4. 主线程等待一段时间,然后关闭ScheduledExecutorService,确保定时任务不再执行。

这是一个基本的使用例子,你可以根据需求调整延迟时间、执行间隔、线程池大小等参数。

ScheduleExecutorService 因其简单易用且性能优异,在各大开源中间件项目(比如 RocketMQ、MetaQ、Canal 等)中被广泛的使用。

3 Spring Task

在Spring框架中,你可以使用@Scheduled注解来创建定时任务。以下是Spring定时任务的基本用法:

  1. 配置类: 创建一个配置类,通常使用 @EnableScheduling 注解启用 Spring 的定时任务功能。

  2. 定时任务方法: 在你的服务类或组件类中创建一个方法,并使用 @Scheduled 注解来指定定时任务的触发条件。

在上述例子中,@Scheduled 注解允许你指定定时任务的执行规则,可以是固定频率(fixedRate)、固定延迟(fixedDelay)、或者使用cron表达式。

4 Quartz

Quartz是一款 Java 开源任务调度框架。

下面我们展示如何使用:

1、添加依赖

2、Job(任务:你要做什么事)

3、Trigger(触发器:什么时候去做)

4、scheduler(任务调度:你什么时候需要做什么事)将 job 与 Trigger 进行整合

下面是一个例子:

这里需要强调的是,Quartz 支持集群模式,持久化方式是 JDBC ,需要创建如下表。

Quartz 集群模式对于业务数据库有侵入性,需要考虑业务场景慎重使用。

5 elastic-job

ElasticJob 定位为轻量级无中心化解决方案,使用 jar 的形式提供分布式任务的协调服务。

应用内部定义任务类,实现 SimpleJob 接口,编写自己任务的实际业务流程即可。

举例:应用A有五个任务需要执行,分别是A,B,C,D,E。任务E需要分成四个子任务,应用部署在两台机器上。

应用A在启动后, 5个任务通过 Zookeeper 协调后被分配到两台机器上,通过Quartz Scheduler 分开执行不同的任务。

ElasticJob 从本质上来讲 ,底层任务调度还是通过 Quartz ,相比Redis分布式锁 或者 Quartz 分布式部署 ,它的优势在于可以依赖 Zookeeper 这个大杀器 ,将任务通过负载均衡算法分配给应用内的 Quartz Scheduler容器。

6 xxl-job

XXL-JOB 是一个使用最广泛的分布式任务调度平台。

业务系统和调度平台分开部署,我们在调度平台上配置应用以及其定时任务,当任务需要执行时,调度平台会触发业务系统的任务,业务系统执行完任务之后,反馈给调度平台任务执行的结果。

接下来,我们使用 xxl-job 开发第一个任务 “Hello World”。

1、新建任务:

登录调度中心,点击下图所示“新建任务”按钮,新建示例任务。然后,参考下面截图中任务的参数配置,点击保存。

2、应用任务开发

3、触发执行

请点击任务右侧 “执行” 按钮,可手动触发一次任务执行(通常情况下,通过配置Cron表达式进行任务调度触发)。

4、查看日志

请点击任务右侧 “日志” 按钮,可前往任务日志界面查看任务日志。在任务日志界面中,可查看该任务的历史调度记录以及每一次调度的任务调度信息、执行参数和执行信息。

运行中的任务点击右侧的“执行日志”按钮,可进入日志控制台查看实时执行日志。

7 写到最后

本文整理了实现定时任务的六种策略,我们需要根据实际场景选择合适的策略。

同时,我们也需要考虑:

  1. 是否需要任务应用集群部署;
  2. 集群部署下假如出现并发执行,业务是否会出现异常;
  3. 如何规避并发执行导致的业务异常。


END



npm被滥用——上传700多个武林外传切片视频



这里有最新开源资讯、软件更新、技术干货等内容

点这里 ↓↓↓ 记得 关注✔ 标星⭐ 哦~

微信扫码关注该文公众号作者

戳这里提交新闻线索和高质量文章给我们。
相关阅读
心力衰竭领域的六大进展速递|年终盘点圣诞新年,Costco六种节日必需品很实惠企业数字化转型赋能 | 「请听讲」第3期:企业数字化转型必须具备的六项关键能力这六种小贵商品, 在Costco买最划算!安省房主注意!1月1日起、出租房子要申请许可证了!每年300刀、不定时审查加拿大国家公园露营预定时间提前了!安省2月5日开始3年虚增利润超2亿元!多名时任高管或被罚,这家A股公司致歉当孩子感到学习太累时,最激励孩子的六句话视觉模型+大语言模型:首个支持10K+帧长视频理解任务的新型框架过节要送礼?圣诞新年,Costco这六种节日必需品物美又价廉无语!时任董监高已全部离职且超过行政处罚时效,公司现任财总被认定为直接负责的主管人员,处以警告,罚款80万!央媒还是出手了!以那英为首的六位明星被制裁家居修理系列:外表篇(5)玻璃窗修理工信部党组《求是》杂志撰文:坚决扛牢实现新型工业化这个关键任务「灌篮高手」模拟人形机器人,一比一照搬人类篮球招式,看一遍就能学会,无需特定任务的奖励宇宙人(1427期)首次实现!祝贺中国科学家;天舟七号船箭组合体转运至发射区;朝鲜宣布:成功;美国“重返月球”任务确定失败七大策略规模以上机构12月业绩快报:12月债券策略再登榜首向妻子泄密!时任鞍钢集团总工程师被罚跟AI竞争的时代,这六种能力能让你增值|罗辑思维向完全自主性更进一步,清华、港大全新跨任务自我进化策略让智能体学会「以经验为鉴」行思时代广场惊现"定时炸弹",债务巨雷倒计时正在响起。2024年加州新法:包括旧金山,圣何塞的六大城市安装超速摄像头,罚单超贵!推荐五类药物,六种措施!世界心脏联合会更新心血管病的二级预防路线图宇宙人(1473期)阿波罗任务“隐藏”了超过20000次月震信息;联发科首次实现大模型在手机芯片端深度适配北大教授钱理群:伪精英的六种病征,他们一旦掌握权力,比一般的贪官污吏危害更大通义千问再开源,Qwen1.5带来六种体量模型,性能超越GPT3.5六种思维展望2024年中国经济七大策略规模以上机构2月业绩快报:主观股票多头策略时隔2年重回榜首大汇总!六种移民方式,总有一款适合您!无题Hush Little Baby (1)首个精通3D任务的具身通才智能体:感知、推理、规划、行动统统拿下A股市场策略:岁末年初关注高股息策略
logo
联系我们隐私协议©2024 redian.news
Redian新闻
Redian.news刊载任何文章,不代表同意其说法或描述,仅为提供更多信息,也不构成任何建议。文章信息的合法性及真实性由其作者负责,与Redian.news及其运营公司无关。欢迎投稿,如发现稿件侵权,或作者不愿在本网发表文章,请版权拥有者通知本网处理。