百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

聊聊定时任务的六种模式 定时任务详解

yuyutoo 2024-12-25 16:32 1 浏览 0 评论

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

1 自定义单线程

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

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

2 JDK ScheduleExecutorService

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-Job 定位为轻量级无中心化解决方案,使用 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. 如何规避并发执行导致的业务异常。

笔者将在接下来的文章里为大家详解定时任务的最佳实践,敬请期待。

如果我的文章对你有所帮助,还请帮忙点赞、在看、转发一下,你的支持会激励我输出更高质量的文章,非常感谢!

相关推荐

GitHub精选 | 基于go开发的定时任务管理系统

《GitHub精选》是我们分享Github中优质项目的栏目,包括技术、学习、实用与各种有趣的内容。本期推荐的是gocron-定时任务管理系统之前有过一期...

linux定时任务,让你更深入的了解系统

cron的软件包cronierpm-qlcronierpm–qlcrontabs最关键的是一个叫做crontab的命令,我们要书写的非系统定时任务就是通过此程序来编写的;要保证crond.se...

linux定时任务详解 linux定时任务执行

配置方式:(记忆口诀:分、时、日、月、星)#Fordetailsseeman4crontabs#Exampleofjobdefinition:#.---------------...

我终于会写 Java 的定时任务了 java定时任务指定时间执行

前言学过定时任务,但是我忘了,忘得一干二净,害怕,一直听别人说:...

如何用Windows计划任务设置:定时关机

定时关机其实是一个小功能,很多时候还真的需要它。你在网上找还真不是那么好找,下面我们用Windows计划任务设置:定时关机,而且,我还在计划任务中看到了几个不该有的计划任务。?打开:计划任务点击Co...

定时任务优化总结(从半个小时优化到秒级)

整体优化思路:1.按需查询、2.分小批次游标查询、3.JED场景下按数据库分片分组更新、4.精准定位要处理的数据、5.负载均衡业务背景:...

信创终端操作系统上定时任务crontab详解 | 统信 | 麒麟 | 中科方德

原文链接:信创终端操作系统上定时任务crontab详解|统信|麒麟|中科方德...

VIVO手机定时任务功能_定时开关机、定时振动模式

手机在生活中是必不可少的,有些功能我们想要他定时切换变更,本文就来分享一下Vivo手机的定时任务功能。Vivo手机如何进入定时任务界面...

下班总是忘记关电脑!添加任务自动定时关机,不用再跑一趟!

我们每个人都有过这样的经历,下班后、或者出差,单位里的电脑总是忘记关机!很是烦恼!经常忘关电脑的话,一是费电,二是不安全,会给网络攻击留有足够的时间,会导致信息泄露,存在安全隐患。其实只要我们在电脑...

为什么定时任务到时间不执行?带你深入源码找答案

前言早上研发经理给我分配了一个开发任务:每5秒统计一次APP在线人数,并问我啥时能上线?我心想这需求用Spring的定时任务完美解决啊!作为一个萌新正好借此机会在经理面前表现一番,于是我拍着胸脯跟经理...

我来总结下 几种定时任务的执行方式

首先带入我们的业务场景:我们买火车票或者叫外卖的时候,下完单之后会跳转到支付页面,页面会有一个计时器,要求在指定时间内完成支付,否则订单自动取消。这是延时任务的一个典型场景,分析这个场景,就是如何在订...

聊聊定时任务的六种模式 定时任务详解

这篇文章,我们聊聊实现定时任务的六种策略。1自定义单线程上图中,我们启动一个线程,该线程无限循环执行,每隔20毫秒执行业务代码。...

windows如何实现定时任务?配合脚本使用结局很满意

序言:作为一名程序员,通过定时任务去实现各种所需的功能是必须要掌握的,本文来讲解一下在windows服务器上如何创建定时任务。有需要的小伙伴赶紧收藏转发吧。第一步:打开控制面板-》系统和安全-》管理工...

电脑(计算机)如何定时执行任务 电脑定时器怎么定时

电脑想定时执行程序,任务计划步骤如下:1,系统服务里,确保"TaskScheduler"服务启动。2,在控制面板->系统和安全里,找到任务计划,并点击:  或在“管理工具”里点...

分布式定时任务最全详解(图文全面总结)

分布式定时任务是非常核心的分布式系统,下面我就全面来详解分布式定时任务以及分布式定时任务框架@mikechen本篇已收于mikechen原创超30万字《阿里架构师进阶专题合集》里面。什么是分布式定时任...

取消回复欢迎 发表评论: