Quartz框架

Quartz框架的介绍

Quartz是一个完全由Java编写的开源任务调度的框架,通过触发器设置作业定时运行规则,控制作业的运行时间。其中quartz集群通过故障切换和负载平衡的功能,能给调度器带来高可用性和伸缩性。主要用来执行定时任务,如:定时发送信息、定时生成报表等等。

Quartz框架的主要特点
  • 强大的调度功能,例如丰富多样的调度方法,可以满足各种常规和特殊需求;
  • 灵活的应用方式,比如支持任务调度和任务的多种组合,支持数据的多种存储;
  • 支持分布式集群,在被Terracotta收购之后,在原来基础上进行了进一步的改造。

Quartz框架的核心元素

Quartz核心要素有Scheduler、Trigger、Job、JobDetail,其中trigger和job、jobDetail为元数据,而Scheduler为实际进行调度的控制器。

在这里插入图片描述
Trigger

Trigger用于定义调度任务的时间规则。

Job

Job用来定义任务的执行逻辑

JobDetail

JobDetail表示一个具体的可执行的调度程序,Job是这个可执行的调度程序所要执行的具体内容,另外JobDetail还包含了这个任务调度的方案和策略

Scheduler

实际执行调度逻辑的控制器(也可以理解为调度容器),可以将多个JobDetail和Trigger注册到Scheduler中,就可以通过Scheduler进行控制执行

Quartz入门使用

  • 引入依赖
<!--定时任务 -->
       <dependency>
            <groupId>org.quartz-scheduler</groupId>
            <artifactId>quartz</artifactId>
            <version>2.2.3</version>
        </dependency>

	 <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-context</artifactId>
            <version>5.0.2.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-tx</artifactId>
            <version>5.0.2.RELEASE</version>
        </dependency>

        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-context-support</artifactId>
            <version>5.0.2.RELEASE</version>
        </dependency>
  • 配置任务类
public class MyJob {
    public void run() {
        System.out.println("执行任务调度:"+new Date());
    }
}
  • 整合spring
<!-- 定义一个任务类 -->
<bean id="myJob" class="cn.itcast.manager.job.MyJob">
</bean>
<!-- 任务类描述 -->
<bean id="jobDetail" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
   <property name="targetObject" ref="myJob"></property>
   <property name="targetMethod" value="run"></property>
</bean>
<!-- 触发器  -->
<bean id="mailTrigger" class="org.springframework.scheduling.quartz.CronTriggerFactoryBean">
   <property name="jobDetail" ref="jobDetail"></property>
   <property name="cronExpression" value="0/5 * * * * ? *"></property>
</bean>
<!-- 总管理容器 -->
<bean id="startQuartz" class="org.springframework.scheduling.quartz.SchedulerFactoryBean" >
   <property name="triggers">
      <list>
         <ref bean="mailTrigger"/>
      </list>
   </property>
</bean>
  • 测试
public class quartzTest {
    public static void main(String[] args) throws Exception {
        ClassPathXmlApplicationContext app  = new ClassPathXmlApplicationContext("classpath:applicationContext-quartz.xml");
        app.start();
        System.in.read();
    }
}

Cron表达式

对于Quartz,我们使用的时候主要是注重两个方面,一个是定时任务的业务,另一个就是Cron表达式

cron表达式的格式
  • QuartzCron 表达式支持到七个域
名称是否必须允许值特殊字符
0-59, - * /
0-59, - * /
0-23, - * /
1-31, - * ? / L W C
1-12 或 JAN-DEC, - * /
1-7 或 SUN-SAT, - * ? / L C #
空 或 1970-2099, - * /

注:月份和星期的名称是不区分大小写的。FRI 和 fri 是一样的。 域之间有空格分隔

特殊字符详解

*星号

使用星号(*) 指示着你想在这个域上包含所有合法的值。例如,在月份域上使用星号意味着每个月都会触发这个 trigger。
表达式样例: 
0 * 17 * * ? 
意义:每天从下午5点到下午5:59中的每分钟激发一次 trigger。它停在下午 5:59 是因为值 17 在小时域上,在下午 6 点时,小时变为 18 了,也就不再理会这个 trigger,直到下一天的下午5点。 在你希望 trigger 在该域的所有有效值上被激发时使用 * 字符。

? 问号

? 号只能用在日和周域上,但是不能在这两个域上同时使用。你可以认为 ? 字符是 "我并不关心在该域上是什么值。" 这不同于星号,星号是指示着该域上的每一个值。? 是说不为该域指定值。 

不能同时这两个域上指定值的理由是难以解释甚至是难以理解的。基本上,假定同时指定值的话,意义就会变得含混不清了:考虑一下,如果一个表达式在日域上有值11,同时在周域上指定了 WED。那么是要 trigger 仅在每个月的11号,且正好又是星期三那天被激发?还是在每个星期三的11号被激发呢?要去除这种不明确性的办法就是不能同时在这两个域上指定值。 只要记住,假如你为这两域的其中一个指定了值,那就必须在另一个字值上放一个 ?。 

表达式样例: 
0 10,44 14 ? 3 WED 
意义:在三月中的每个星期三的下午 2:10 和 下午 2:44 被触发。

, 逗号

逗号 (,) 是用来在给某个域上指定一个值列表的。例如,使用值 0,15,30,45 在秒域上意味着每15秒触发一个 trigger。 
表达式样例: 
0 0,15,30,45 * * * ? 
意义:每刻钟触发一次 trigger。

/ 斜杠

斜杠 (/) 是用于时间表的递增的。我们刚刚用了逗号来表示每15分钟的递增,但是我们也能写成这样 0/15。
表达式样例: 
0/15 0/30 * * * ? 
意义:在整点和半点时每15秒触发 trigger。

-中划线

中划线 (-) 用于指定一个范围。例如,在小时域上的 3-8 意味着 "3,4,5,6,7 和 8 点。"  域的值不允许回转,所以像 50-10 这样的值是不允许的。 
表达式样例: 
0 45 3-8 ? * * 
意义:在上午的3点至上午的8点的45分时触发 trigger。

L 字母

L 说明了某域上允许的最后一个值。它仅被日和周域支持。当用在日域上,表示的是在月域上指定的月份的最后一天。例如,当月域上指定了 JAN 时,在日域上的 L 会促使 trigger 在1月31号被触发。假如月域上是 SEP,那么 L 会预示着在9月30号触发。换句话说,就是不管指定了哪个月,都是在相应月份的时最后一天触发 trigger。 
表达式 0 0 8 L * ? 意义是在每个月最后一天的上午 8:00 触发 trigger。在月域上的 * 说明是 "每个月"。 
当 L 字母用于周域上,指示着周的最后一天,就是星期六 (或者数字7)。所以如果你需要在每个月的最后一个星期六下午的 11:59 触发 trigger,你可以用这样的表达式 0 59 23 ? * L。 
当使用于周域上,你可以用一个数字与 L 连起来表示月份的最后一个星期 X。例如,表达式 0 0 12 ? * 2L 说的是在每个月的最后一个星期一触发 trigger。 
不要让范围和列表值与 L 连用
虽然你能用星期数(1-7)与 L 连用,但是不允许你用一个范围值和列表值与 L 连用。这会产生不可预知的结果。

W 字母

W 字符代表着平日 (Mon-Fri),并且仅能用于日域中。它用来指定离指定日的最近的一个平日。大部分的商业处理都是基于工作周的,所以 W 字符可能是非常重要的。例如,日域中的 15W 意味着 "离该月15号的最近一个平日。" 假如15号是星期六,那么 trigger 会在14号(星期四)触发,因为距15号最近的是星期一,这个例子中也会是17号(译者Unmi注:不会在17号触发的,如果是15W,可能会是在14号(15号是星期六)或者15号(15号是星期天)触发,也就是只能出现在邻近的一天,如果15号当天为平日直接就会当日执行)。W 只能用在指定的日域为单天,不能是范围或列表值。

#井号

字符仅能用于周域中。它用于指定月份中的第几周的哪一天。例如,如果你指定周域的值为 6#3,它意思是某月的第三个周五 (6=星期五,#3意味着月份中的第三周)。另一个例子 2#1 意思是某月的第一个星期一 (2=星期一,#1意味着月份中的第一周)。注意,假如你指定 #5,然而月份中没有第 5 周,那么该月不会触发。 
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Quartz是OpenSymphony开源组织在Job scheduling领域又一个开源项目,它可以与J2EE与J2SE应用程序相结合也可以单独使用。Quartz可以用来创建简单或为运行十个,百个,甚至是好几万个Jobs这样复杂的程序。Jobs可以做成标准的Java组件或 EJBs。 Quartz的优势: 1、Quartz是一个任务调度框架(库),它几乎可以集成到任何应用系统中。 2、Quartz是非常灵活的,它让您能够以最“自然”的方式来编写您的项目的代码,实现您所期望的行为 3、Quartz是非常轻量级的,只需要非常少的配置 —— 它实际上可以被跳出框架来使用,如果你的需求是一些相对基本的简单的需求的话。 4、Quartz具有容错机制,并且可以在重启服务的时候持久化(”记忆”)你的定时任务,你的任务也不会丢失。 5、可以通过Quartz,封装成自己的分布式任务调度,实现强大的功能,成为自己的产品。6、有很多的互联网公司也都在使用Quartz。比如美团 Spring是一个很优秀的框架,它无缝的集成了Quartz,简单方便的让企业级应用更好的使用Quartz进行任务的调度。   课程说明:在我们的日常开发中,各种大型系统的开发少不了任务调度,简单的单机任务调度已经满足不了我们的系统需求,复杂的任务会让程序猿头疼, 所以急需一套专门的框架帮助我们去管理定时任务,并且可以在多台机器去执行我们的任务,还要可以管理我们的分布式定时任务。本课程从Quartz框架讲起,由浅到深,从使用到结构分析,再到源码分析,深入解析Quartz、Spring+Quartz,并且会讲解相关原理, 让大家充分的理解这个框架框架的设计思想。由于互联网的复杂性,为了满足我们特定的需求,需要对Spring+Quartz进行二次开发,整个二次开发过程都会进行讲解。Spring被用在了越来越多的项目中, Quartz也被公认为是比较好用的定时器设置工具,学完这个课程后,不仅仅可以熟练掌握分布式定时任务,还可以深入理解大型框架的设计思想。
Quartz框架是一个用于调度和执行定时任务的开源框架,其原理可以概括如下: 1. 调度器(Scheduler):Quartz框架的核心组件,负责管理和调度定时任务的执行。调度器可以创建多个执行线程,并根据配置的策略决定任务的执行时间和频率。 2. 作业(Job):表示要执行的具体任务逻辑。可以通过实现Job接口或继承Quartz提供的抽象类(如QuartzJobBean)来定义作业。每个作业都有一个唯一的标识符,用来在调度器中进行管理。 3. 触发器(Trigger):用于触发作业的执行。触发器定义了作业何时被执行的时间表。Quartz框架提供了多种类型的触发器,如SimpleTrigger、CronTrigger等,可以根据具体需求选择合适的触发器类型。 4. 作业存储(JobStore):用于存储作业和触发器的信息。Quartz框架提供了多种作业存储的实现方式,如RAMJobStore、JDBCJobStore等。作业存储负责维护作业和触发器的状态,并提供查询、删除、更新等操作。 5. 监听器(Listener):用于监听作业和触发器的状态变化,如作业执行前后、触发器触发前后等。通过实现监听器接口,可以自定义监听器来处理特定的事件。 Quartz框架的工作流程如下: 1. 配置调度器:创建调度器实例,并配置相关属性,如线程池大小、作业存储方式等。 2. 定义作业和触发器:创建作业实例,并定义触发器的执行时间表。将作业和触发器关联起来。 3. 启动调度器:调用调度器的start方法,启动调度器,开始定时任务的调度和执行。 4. 调度执行:根据触发器的定义,调度器会根据预定的时间表触发作业的执行。调度器会选择一个可用的执行线程来执行作业。 5. 监听和处理事件:根据配置的监听器,监听作业和触发器的状态变化,如作业执行前后、触发器触发前后等。根据监听器的逻辑处理相应的事件。 6. 停止调度器:当不再需要定时任务时,可以调用调度器的shutdown方法,停止调度器的运行。 总的来说,Quartz框架通过调度器、作业、触发器、作业存储和监听器等组件的协作,实现了定时任务的调度和执行。通过配置和管理这些组件,可以灵活地实现各种定时任务的需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值