在你使用調(diào)度器之前,需要借助一些具體的例子去理解它。你可以使用 SchedulerFactory 類來達到程序調(diào)度的目的。有一些 Quartz 框架的用戶可能會將 Factory 的實例存儲在 JND I中,其他人為了便于舉例子就直接使用 Factory 的實例。
一旦調(diào)度器實例化后,它就能夠啟動,等待執(zhí)行和關閉。需要注意的是一旦調(diào)度器調(diào)用 了shutdown 方法關閉后,如果不重新實例化,它就不會啟動了。觸發(fā)器在調(diào)度器未啟動時,或是終止狀態(tài)時,都不會被觸發(fā)。
quartz 的簡單事例:
public class HelloJob implements Job {
@Override
public void execute(JobExecutionContext context) throws JobExecutionException {
Object tv1 = context.getTrigger().getJobDataMap().get("t1");
Object tv2 = context.getTrigger().getJobDataMap().get("t2");
Object jv1 = context.getJobDetail().getJobDataMap().get("j1");
Object jv2 = context.getJobDetail().getJobDataMap().get("j2");
Object sv = null;
try {
sv = context.getScheduler().getContext().get("skey");
} catch (SchedulerException e) {
e.printStackTrace();
}
System.out.println(tv1+":"+tv2);
System.out.println(jv1+":"+jv2);
System.out.println(sv);
System.out.println("hello:"+LocalDateTime.now());
}
}
public class Test {
public static void main(String[] args) throws SchedulerException {
//創(chuàng)建一個scheduler
Scheduler scheduler = StdSchedulerFactory.getDefaultScheduler();
scheduler.getContext().put("skey", "svalue");
//創(chuàng)建一個Trigger
Trigger trigger = TriggerBuilder.newTrigger()
.withIdentity("trigger1", "group1")
.usingJobData("t1", "tv1")
.withSchedule(SimpleScheduleBuilder.simpleSchedule().withIntervalInSeconds(3)
.repeatForever()).build();
trigger.getJobDataMap().put("t2", "tv2");
//創(chuàng)建一個job
JobDetail job = JobBuilder.newJob(HelloJob.class)
.usingJobData("j1", "jv1")
.withIdentity("myjob", "mygroup").build();
job.getJobDataMap().put("j2", "jv2");
//注冊trigger并啟動scheduler
scheduler.scheduleJob(job,trigger);
scheduler.start();
}
}
更多建議: