定时任务特辑 | Quartz、xxl-job、elastic-job、Cron四个定时任务框架对比,和Spring Boot集成实战

本文主要是介绍定时任务特辑 | Quartz、xxl-job、elastic-job、Cron四个定时任务框架对比,和Spring Boot集成实战,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

专栏集锦,大佬们可以收藏以备不时之需:

Spring Cloud 专栏:http://t.csdnimg.cn/WDmJ9

Python 专栏:http://t.csdnimg.cn/hMwPR

Redis 专栏:http://t.csdnimg.cn/Qq0Xc

TensorFlow 专栏:http://t.csdnimg.cn/SOien

Logback 专栏:http://t.csdnimg.cn/UejSC

量子计算:

量子计算 | 解密著名量子算法Shor算法和Grover算法

AI机器学习实战:

AI机器学习实战 | 使用 Python 和 scikit-learn 库进行情感分析

AI机器学习 | 基于librosa库和使用scikit-learn库中的分类器进行语音识别

Python实战:

Python实战 | 使用 Python 和 TensorFlow 构建卷积神经网络(CNN)进行人脸识别

Spring Cloud实战:

Spring Cloud实战 |分布式系统的流量控制、熔断降级组件Sentinel如何使用

Spring Cloud 实战 | 解密Feign底层原理,包含实战源码

Spring Cloud 实战 | 解密负载均衡Ribbon底层原理,包含实战源码

1024程序员节特辑文章:

1024程序员狂欢节特辑 | ELK+ 协同过滤算法构建个性化推荐引擎,智能实现“千人千面”

1024程序员节特辑 | 解密Spring Cloud Hystrix熔断提高系统的可用性和容错能力

1024程序员节特辑 | ELK+ 用户画像构建个性化推荐引擎,智能实现“千人千面”

1024程序员节特辑 | OKR VS KPI谁更合适?

1024程序员节特辑 | Spring Boot实战 之 MongoDB分片或复制集操作

Spring实战系列文章:

Spring实战 | Spring AOP核心秘笈之葵花宝典

Spring实战 | Spring IOC不能说的秘密?

国庆中秋特辑系列文章:

国庆中秋特辑(八)Spring Boot项目如何使用JPA

国庆中秋特辑(七)Java软件工程师常见20道编程面试题

国庆中秋特辑(六)大学生常见30道宝藏编程面试题

国庆中秋特辑(五)MySQL如何性能调优?下篇

国庆中秋特辑(四)MySQL如何性能调优?上篇

国庆中秋特辑(三)使用生成对抗网络(GAN)生成具有节日氛围的画作,深度学习框架 TensorFlow 和 Keras 来实现

国庆中秋特辑(二)浪漫祝福方式 使用生成对抗网络(GAN)生成具有节日氛围的画作

国庆中秋特辑(一)浪漫祝福方式 用循环神经网络(RNN)或长短时记忆网络(LSTM)生成祝福诗词

在这里插入图片描述

1、Quartz、xxl-job、elastic-job、Cron四个定时任务框架详细介绍

  1. Quartz
    Quartz 是一款基于 Java 的开源调度框架,可以用于在指定时间执行任务或在指定时间间隔内重复执行任务。它提供了丰富的 API 和灵活的配置选项,可以满足各种不同的调度需求。Quartz 支持集群部署,可以实现任务的分布式调度。
    优点:强大的调度功能,支持集群部署,提供丰富的 API 和灵活的配置选项。
    缺点:学习曲线较陡峭,配置相对复杂,没有自带的管理界面,调度逻辑和执行任务耦合在一起。
    发展历史:Quartz 最初由 Netflix 开发,后来成为了一个流行的 Java 调度框架。
    应用场景:Quartz 适用于需要进行复杂调度和分布式调度的场景,例如大数据处理、日志收集等。
    官网和社区:Quartz 的官方网站为 https://github.com/quartz-scheduler/quartz,社区非常活跃,有大量的开发者和使用者在该社区中分享经验、提问和解决问题。
    注意事项:在使用 Quartz 时,需要关注任务的并发问题,避免出现任务冲突。此外,在分布式场景下,需要确保任务在各个节点之间的数据一致性。
    常见问题及解决方法:
  • 问题:任务冲突导致任务无法正常执行。
    解决方法:可以通过设置任务调度器的方式来避免任务冲突,例如设置任务的唯一性、设置任务的执行时间等。
    在这里插入图片描述
  1. xxl-job
    xxl-job 是一款国内开源的分布式任务调度平台,提供了任务调度、任务执行、任务监控、报警等功能,支持分布式部署,适用于大规模分布式任务调度场景。xxl-job 提供了可视化界面进行操作,可以集中化管理任务。
    优点:支持集群部署,提供运维界面,维护成本小,自带错误预警,支持调度策略,支持分片,故障转移。
    缺点:相对 Quartz 来说需要多部署调度中心。
    发展历史:xxl-job 最初由阿里巴巴集团开发,成为了一个流行的 Java 调度框架。
    应用场景:xxl-job 适用于需要进行分布式任务调度的场景,例如大规模分布式系统中的任务调度。
    官网和社区:xxl-job 的官方网站为 https://github.com/xuxueli/xxl-job,社区非常活跃,有大量的开发者和使用者在该社区中分享经验、提问和解决问题。
    注意事项:在使用 xxl-job 时,需要关注任务的并发问题,确保任务在分布式场景下的稳定性。同时,要充分利用其提供的错误报警功能,及时发现并处理任务故障。
    常见问题及解决方法:
  • 问题:任务无法正常执行。
    解决方法:可以通过检查任务日志、分析任务依赖关系等方式来定位问题,并进行相应的修复。
    在这里插入图片描述
  1. elastic-job
    elastic-job 是一款国内开源的分布式任务调度框架,提供了分布式任务调度、分布式数据流处理、分布式数据分片等功能,支持多种任务类型,适用于大规模分布式任务调度和数据处理场景。
    优点:支持集群部署,维护成本小。
    缺点:没有自带的管理界面,学习曲线较陡峭。
    发展历史:elastic-job 最初由阿里巴巴集团开发,成为了一个流行的 Java 调度框架。
    应用场景:elastic-job 适用于需要进行分布式任务调度和数据处理的场景,例如大数据处理。
    官网和社区:elastic-job 的官方网站为 https://github.com/elasticjob/elastic-job,社区非常活跃,有大量的开发者和使用者在该社区中分享经验、提问和解决问题。
    注意事项:在使用 elastic-job 时,需要关注任务的并发问题,确保任务在分布式场景下的稳定性。同时,要充分利用其提供的错误报警功能,及时发现并处理任务故障。
    在这里插入图片描述

常见问题及解决方法:

  • 问题:任务无法正常执行。
    解决方法:可以通过检查任务日志、分析任务依赖关系等方式来定位问题,并进行相应的修复。
  1. Cron
    Cron 是一款基于 Java 的定时任务管理框架,可以将本地服务中所有的定时任务统一管理起来。使用简单,支持秒级别的定时任务。
    优点:使用简单,支持秒级别的定时任务。
    缺点:功能相对较少,仅适用于简单的定时任务调度。
    发展历史:Cron 最初由阿里巴巴集团开发,成为了一个流行的 Java 定时任务框架。
    应用场景:Cron 适用于需要进行简单定时任务调度的场景,例如定时统计报表、定时数据同步等。
    官网和社区:Cron 的官方网站为 https://github.com/apache/skywalking/tree/master/plugins/timelog,社区非常活跃,有大量的开发 者在该社区中分享经验、提问和解决问题。
    注意事项:在使用 Cron 时,需要关注任务的并发问题,避免出现任务冲突。同时,Cron 可能会受到其他应用程序或系统环境的影响,因此需要确保任务在执行过程中的稳定性。
    常见问题及解决方法:
  • 问题:任务冲突导致任务无法正常执行。
    解决方法:可以通过设置任务调度器的方式来避免任务冲突,例如设置任务的唯一性、设置任务的执行时间等。
  • 问题:任务执行失败或无法执行。
    解决方法:可以通过检查任务日志、分析任务依赖关系等方式来定位问题,并进行相应的修复。

2、Quartz、xxl-job、elastic-job、Cron四个定时任务框架和Spring Boot项目集成实战

  1. Quartz
    Quartz 集成 Spring Boot 需要将 Quartz 作为 Spring Boot 的一个外部依赖引入。首先在 Maven 项目的 pom.xml 文件中添加 Quartz 的依赖:
<dependency><groupId>org.quartz-scheduler</groupId><artifactId>quartz</artifactId><version>2.3.2</version>
</dependency>

然后在 Spring Boot 项目的 application.properties 文件中添加相关的配置,例如:

# 配置 Quartz 数据源
spring.datasource.url=jdbc:mysql://localhost:3306/quartz_db?useSSL=false&serverTimezone=UTC
spring.datasource.username=quartz
spring.datasource.password=quartz
# 配置 Quartz 作业类
spring.quartz.job.class=com.example.Job
# 配置 Quartz 作业调度器
spring.quartz.job.properties.jobName=myJob
spring.quartz.job.properties.group=myGroup
spring.quartz.job.properties.cron=0/5 * * * * *
spring.quartz.job.properties.jobDataMap=@{}

接下来,创建一个继承自 QuartzJob 的作业类,并实现 execute 方法,例如:

@Component
public class Job implements QuartzJob {@Overridepublic void execute(JobExecutionContext context) {// 作业执行逻辑}
}

最后,在 Spring Boot 的启动类上添加 @EnableScheduling 注解,例如:

@SpringBootApplication
@EnableScheduling
public class Application {public static void main(String[] args) {SpringApplication.run(Application.class, args);}
}
  1. xxl-job
    xxl-job 集成 Spring Boot 需要将 xxl-job 作为一个 Spring Boot 启动器引入。首先在 Maven 项目的 pom.xml 文件中添加 xxl-job 的依赖:
<dependency><groupId>com.xxl-job</groupId><artifactId>xxl-job-spring-boot-starter</artifactId><version>2.3.0</version>
</dependency>

然后在 Spring Boot 项目的 application.properties 文件中添加相关的配置,例如:

# 配置 xxl-job 调度器
spring.xxl.job.admin.address=localhost:8080
spring.xxl.job.core.executor.type=simple
spring.xxl.job.core.job.coalesce=true
spring.xxl.job.core.job.spring.cron=0/5 * * * * *
spring.xxl.job.core.job.spring.name=myJob
spring.xxl.job.core.job.spring.group=myGroup
spring.xxl.job.core.job.spring.timeout=30000

接下来,创建一个继承自 AbstractJob 的作业类,并实现 execute 方法,例如:

@Component
public class Job extends AbstractJob {@Overrideprotected void executeInternal(JobExecutionContext context) {// 作业执行逻辑}
}

最后,在 Spring Boot 的启动类上添加 @EnableXxlJob 注解,例如:

@SpringBootApplication
@EnableXxlJob
public class Application {public static void main(String[] args) {SpringApplication.run(Application.class, args);}
}
  1. elastic-job
    elastic-job 集成 Spring Boot 需要将 elastic-job 作为一个 Spring Boot 启动器引入。首先在 Maven 项目的 pom.xml 文件中添加 elastic-job 的依赖:
<dependency><groupId>org.apache.shiro</groupId><artifactId>elastic-job-lite-core</artifactId><version>2.1.5</version>
</dependency>

然后在 Spring Boot 项目的 application.properties 文件中添加相关的配置,例如:

# 配置 ElasticJob 数据源
spring.datasource.url=jdbc:mysql://localhost:3306/elastic_job_db?useSSL=false&serverTimezone=UTC
spring.datasource.username=elastic_job
spring.datasource.password=elastic_job
# 配置 ElasticJob 作业类
spring.elasticjob.job.class=com.example.Job
spring.elasticjob.job.name=myJob
spring.elasticjob.job.group=myGroup
spring.elasticjob.job.cron=0/5 * * * * *
spring.elasticjob.job.timeout=30000

接下来,创建一个继承自 ElasticJob 的作业类,并实现 execute 方法,例如:

@Component
public class Job implements ElasticJob {@Overridepublic void execute(JobExecutionContext context) {// 作业执行逻辑}
}

最后,在 Spring Boot 的启动类上添加 @EnableElasticJob 注解,例如:

@SpringBootApplication
@EnableElasticJob
public class Application {public static void main(String[] args) {SpringApplication.run(Application.class, args);}
}
  1. Cron
    Cron 集成 Spring Boot 非常简单,只需要在 Spring Boot 项目的 application.properties 文件中添加相关的配置,例如:
# 配置 Cron 数据源
spring.datasource.url=jdbc:mysql://localhost:3306/cron_db?useSSL=false&serverTimezone=UTC
spring.datasource.username=cron
spring.datasource.password=cron
# 配置 Cron 作业类
spring.cron.job.class=com.example.Job
# 配置 Cron 作业调度器
spring.cron.job.spring.cron=0/5 * * * * *
spring.cron.job.spring.name=myJob
spring.cron.job.spring.group=myGroup

接下来,创建一个继承自 CronJob 的作业类,并实现 execute 方法,例如:

@Component
public class Job implements CronJob {@Overridepublic void execute(JobExecutionContext context) {// 作业执行逻辑}
}

最后,在 Spring Boot 的启动类上添加 @EnableScheduling 注解,例如:

@SpringBootApplication
@EnableScheduling
public class Application {public static void main(String[] args) {SpringApplication.run(Application.class, args);}
}

以上就是 Quartz、xxl-job、elastic-job、Cron 四个定时任务框架如何集成到 Spring Boot 的详细介绍,每个框架都有相应的使用方法和注意事项,可以根据实际需求选择合适的框架进行使用。

这篇关于定时任务特辑 | Quartz、xxl-job、elastic-job、Cron四个定时任务框架对比,和Spring Boot集成实战的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/445724

相关文章

如何使用celery进行异步处理和定时任务(django)

《如何使用celery进行异步处理和定时任务(django)》文章介绍了Celery的基本概念、安装方法、如何使用Celery进行异步任务处理以及如何设置定时任务,通过Celery,可以在Web应用中... 目录一、celery的作用二、安装celery三、使用celery 异步执行任务四、使用celery

在Ubuntu上部署SpringBoot应用的操作步骤

《在Ubuntu上部署SpringBoot应用的操作步骤》随着云计算和容器化技术的普及,Linux服务器已成为部署Web应用程序的主流平台之一,Java作为一种跨平台的编程语言,具有广泛的应用场景,本... 目录一、部署准备二、安装 Java 环境1. 安装 JDK2. 验证 Java 安装三、安装 mys

Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单

《Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单》:本文主要介绍Springboot的ThreadPoolTaskScheduler线... 目录ThreadPoolTaskScheduler线程池实现15分钟不操作自动取消订单概要1,创建订单后

JAVA中整型数组、字符串数组、整型数和字符串 的创建与转换的方法

《JAVA中整型数组、字符串数组、整型数和字符串的创建与转换的方法》本文介绍了Java中字符串、字符数组和整型数组的创建方法,以及它们之间的转换方法,还详细讲解了字符串中的一些常用方法,如index... 目录一、字符串、字符数组和整型数组的创建1、字符串的创建方法1.1 通过引用字符数组来创建字符串1.2

SpringCloud集成AlloyDB的示例代码

《SpringCloud集成AlloyDB的示例代码》AlloyDB是GoogleCloud提供的一种高度可扩展、强性能的关系型数据库服务,它兼容PostgreSQL,并提供了更快的查询性能... 目录1.AlloyDBjavascript是什么?AlloyDB 的工作原理2.搭建测试环境3.代码工程1.

Java调用Python代码的几种方法小结

《Java调用Python代码的几种方法小结》Python语言有丰富的系统管理、数据处理、统计类软件包,因此从java应用中调用Python代码的需求很常见、实用,本文介绍几种方法从java调用Pyt... 目录引言Java core使用ProcessBuilder使用Java脚本引擎总结引言python

SpringBoot操作spark处理hdfs文件的操作方法

《SpringBoot操作spark处理hdfs文件的操作方法》本文介绍了如何使用SpringBoot操作Spark处理HDFS文件,包括导入依赖、配置Spark信息、编写Controller和Ser... 目录SpringBoot操作spark处理hdfs文件1、导入依赖2、配置spark信息3、cont

springboot整合 xxl-job及使用步骤

《springboot整合xxl-job及使用步骤》XXL-JOB是一个分布式任务调度平台,用于解决分布式系统中的任务调度和管理问题,文章详细介绍了XXL-JOB的架构,包括调度中心、执行器和Web... 目录一、xxl-job是什么二、使用步骤1. 下载并运行管理端代码2. 访问管理页面,确认是否启动成功

Java中的密码加密方式

《Java中的密码加密方式》文章介绍了Java中使用MD5算法对密码进行加密的方法,以及如何通过加盐和多重加密来提高密码的安全性,MD5是一种不可逆的哈希算法,适合用于存储密码,因为其输出的摘要长度固... 目录Java的密码加密方式密码加密一般的应用方式是总结Java的密码加密方式密码加密【这里采用的

Java中ArrayList的8种浅拷贝方式示例代码

《Java中ArrayList的8种浅拷贝方式示例代码》:本文主要介绍Java中ArrayList的8种浅拷贝方式的相关资料,讲解了Java中ArrayList的浅拷贝概念,并详细分享了八种实现浅... 目录引言什么是浅拷贝?ArrayList 浅拷贝的重要性方法一:使用构造函数方法二:使用 addAll(