Quartz教程 - 1Quartz简介

更好的阅读体验:点这里www.doubibiji.com

1 Quartz简介

1.1 什么是Quartz

我们在项目中经常会需要执行一些定时任务,例如定时进行数据备份和清理;定时检查创建的订单有没有支付,没有支付超过30分钟就将其取消,这些都会用到定时任务。

Quartz 就是一个开源的、用于 Java 编程语言的任务调度框架。它的主要作用是允许开发者根据预定的时间执行特定的任务。这些任务可以是一次性的,也可以是周期性的,Quartz 可以有效地管理这些任务的执行。

1.2 Quartz中的核心组件

在动手编码之前,先了解一下 Quartz 中的核心组件。

  • 任务 Job

    也就是任务,需要被定时执行的任务

  • 触发器 Trigger

    定义了 Job 的执行时间规则。它确定了 Job 何时被执行。Quartz 提供了不同类型的 Trigger,允许根据不同的时间规则安排 Job 的执行。

  • 调度器 Scheduler

    Scheduler 是 Quartz 的核心,负责管理 Job 和 Trigger,控制它们的执行。它可以启动、暂停、停止和重新启动任务的执行,并管理它们的生命周期。

  • 任务存储 JobStore

    JobStore 负责存储 Quartz 的状态信息,包括 Job、Trigger、调度信息等。它存储了所有被调度的任务和相关的配置信息,确保即使在重启后也能恢复调度器的状态。

架构图如下:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

在使用的时候,通过 JobBuilder 构建 JobDetailJobDetailJob 进行了包装,添加了更多的信息描述。

通过 TriggerBuilder 创建 Trigger,触发器一般有4种,最常用的就是 CronTrigger 了。多个触发器是可以执行同一个任务的。

通过 SchedulerFactory 创建 Scheduler,使用 Scheduler 来管理任务信息和触发器;

监听器有三大类,可以分别用来监听任务信息、触发器和调度器的执行情况、生命周期等信息。

JobStore 部分负责 Quartz 信息的存储,默认是使用 RAMJobStore 存储在内存中的,重启后,信息会丢失;JDBCJobStore 是数据库存储,在集群的时候,就需要用到数据库存储,各个节点共享数据库的信息。

  • 7
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

山石岐渡

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值