Quartz任务调度框架相关方法、参数理解

Quartz API中的关键接口

  • Job : Quartz提供的需实现的需调度器执行的任务组件接口,只有唯一接口:  void execute(JobExecutionContext var1) throws JobExecutionException;
  • job.class :实现了execute接口的作业类
  • JobDetail : 定义作业的实例,实现的任务组件类在此被作为参数传入实例
  • Trigger :触发器,定义作业执行计划的组件
  • JobBuilder : 用来构建JobDetail实例
  • TriggerBuilder : 用来构建Trigger实例
  • Scheduler :与调度程序交互的主要API,组合JobDetail和Trigger,启动任务调度,Scheduler在执行start后,触发Trigger,执行JobDetail

下面来说说各个接口之间的关系

1、Job和Trigger

Trigger被触发时,excuate()被调度程序的一个工作线程调用,传递给excuate方法的参数JobExecutionContext中包含该Job实例中的所有运行参数(SchedulerJobDetailTrigger),保存在JobDataMap中。

Quartz提供了多种不同类型的Trigger,最常用的两种:SimpleTriggerCronTrigger

前者主要执行一些简单的定时调度,后者更突出的是在基于日历调度上的优势,比如每年的第2周的星期34:00执行。

多数的任务调度框架将作业任务与调度任务都放在一起。Quartz将任务调度(Trigger)和作业任务(JobDetail)分开的理由如下:

*作业任务与调度分开,当一个任务调度执行完毕后,可重新组装Trigger与JobDetail重新启用原来的作业任务,不用重新定义,的卢换马铠变赤兔,同样,同一个Trigger也可以重复和多个JobDetail组合使用,减少了耦合,提高了重用性。

将Job和Trigger注册到Scheduler 时可为他们设置key(JobKeyTriggerKey)配置其身份属性,进而可以将他们放在不通分组(group)中,可基于分组操作。不同分组中的key值必须唯一,也可以理解为key值由name和group组成,必须唯一

Job的并发

@DisallowConcurrentExecution

@PersistJobDataAfterExecution

 未完待续。。。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值