// 1、调度器 - 从工厂获取调度实例
Scheduler scheduler = StdSchedulerFactory.getDefaultScheduler();
// 2、任务实例 - 执行的任务对象
JobDetail job = JobBuilder.newJob(HelloJob.class)
.withIdentity(“job1”, “group1”) // 任务名称,组名称
.build();
// 3、触发器 - 控制执行次数和执行时间
Trigger trigger = TriggerBuilder.newTrigger()
.withIdentity(“trigger1”, “group1”) // 同上
.startNow() // 立刻启动
.withSchedule(SimpleScheduleBuilder.simpleSchedule().
withIntervalInSeconds(3).
withRepeatCount(10)) // 循环10次,每次间隔3s
.build();
// 调度器关联触发器,并启动
scheduler.scheduleJob(job,trigger);
scheduler.start();
}
}
1.3 Job 与 JobDetail
Job:基于反射的任务调度接口,所有任务类都要实现该接口,在接口的 execute
里编写自己的业务逻辑。
Job 生命周期:每次执行 Job,在 execute 方法前会 创建新的 Job实例
,调用后实例被释放,再被GC回收。
JobDetail:封装 Job,给 Job 实例提供许多属性。
JobDetail 属性:name、group、jobClass、jobDataMap。
1.4 JobExecutionContext
下文将 JobExecutionContext 简称为 JEC
JEC :当调度器调用 Job 时,会将 JEC 传递给 Job 的 execute 方法。
JEC 作用:Job 通过 JEC 获取运行环境信息,以及 Job 信息。
1.5 JobDataMap
下文将 JobDataMap 简称为 JDM
JDM:任务调度时,JDM 存储在 JEC 中,方便获取。
JDM 优点:实现 Map 接口,可以存取任何可序列化对象,Job 执行时会将参数传给 JDM。
1、手动获取 JDM 参数案例
HelloSchedulerDemo:
package com.sugar.quartz.utils;
import org.quartz.*;
import org.quartz.impl.StdSchedulerFactory;
/**
* 功能描述: 定时器配置
*
* @author XiaoNianXin
* @date 2021/12/13 21:08
*/
public class HelloSchedulerDemo {
public static void main(String[] args) throws SchedulerException {
// 1、调度器 - 从工厂获取调度实例
Scheduler scheduler = StdSchedulerFactory.getDefaultScheduler();