触发器通用属性:
jobKey:表示job实例的标识,触发器被触发时,指定的job实例会被执行。
startTime:表示触发器的时间表 首次被触发的时间,他的值类型为java.uti.Date。
endTime:指定的触发器不在被执行的时间,他的值类型为java.uti.Date。
实现:
package quartz; import java.text.SimpleDateFormat; import java.util.Date; import org.quartz.JobBuilder; import org.quartz.JobDetail; import org.quartz.Scheduler; import org.quartz.SchedulerException; import org.quartz.SchedulerFactory; import org.quartz.SimpleScheduleBuilder; import org.quartz.Trigger; import org.quartz.TriggerBuilder; import org.quartz.impl.StdSchedulerFactory; public class SchedulerClass { public static void main(String[] args) throws SchedulerException { Date startDate = new Date(); SimpleDateFormat sf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); System.out.println("当前时间:"+sf.format(startDate)); // 创建一个JobDetail实例 // 将该实例与JobClass绑定,JobDetail是由Builder模式来创建的,JobDetail是来绑定job的。 // withIdentity 创建唯一的标识 JobDetail jobDetail = JobBuilder.newJob(JobClass.class).withIdentity("jobName", "group").build(); /*获取当前三秒后的时间*/ startDate.setTime(startDate.getTime()+3000); /*获取当前六秒后的时间*/ Date endDate = new Date(); endDate.setTime(endDate.getTime()+6000); // 创建一个Tigger实例,定义 job立即执行,并每隔一段时间重复执行,每隔5秒中执行一次 Trigger trigger = TriggerBuilder.newTrigger().withIdentity("trigger").startAt(startDate).endAt(endDate) .withSchedule(SimpleScheduleBuilder.simpleSchedule().withIntervalInSeconds(5).repeatForever()).build(); // 创建一个Scheduler实例, Scheduler是由工厂模式来创建的 so SchedulerFactory factory = new StdSchedulerFactory(); Scheduler scheduler = factory.getScheduler(); scheduler.start(); // 调度器调用任务和触发器,scheduler将job,trigger绑定在一起。 scheduler.scheduleJob(jobDetail, trigger); } }
package quartz; import java.text.SimpleDateFormat; import java.util.Date; import org.quartz.Job; import org.quartz.JobDataMap; import org.quartz.JobDetail; import org.quartz.JobExecutionContext; import org.quartz.JobExecutionException; import org.quartz.JobKey; import org.quartz.Trigger; public class JobClass implements Job { public void execute(JobExecutionContext arg0) throws JobExecutionException { Date date=new Date(); SimpleDateFormat sf=new SimpleDateFormat( "yyyy-MM-dd HH:mm:ss"); System.out.println("执行时间:"+sf.format(date)); // 编写业务逻辑 System.out.println("hello Quartz"); JobKey jobKey=arg0.getJobDetail().getKey(); Trigger triiger=arg0.getTrigger(); System.out.println("开始时间"+sf.format(triiger.getStartTime())); System.out.println("结束时间"+sf.format(triiger.getEndTime())); System.out.println("实例名称:"+jobKey.getName()); } }
执行结果为:
SimpleTrigger
作用:在指定的时间段内执行一次作业任务 或是 在指定的时间间隔内执行多次作业任务 (定时定频率)
// 定时 当前时间3秒后执行 startDate.setTime(startDate.getTime() + 3000); // Trigger trigger =TriggerBuilder.newTrigger().withIdentity("trigger").startAt(startDate).build(); // 定频率 每隔3秒中执行一次,执行2次 Trigger trigger = TriggerBuilder.newTrigger().withIdentity("trigger").startNow() .withSchedule(SimpleScheduleBuilder.simpleSchedule().withIntervalInSeconds(3).withRepeatCount(2)).build();
注意:
重复次数,可以是0、正整数,以及常量SimpleTrigger.REPEAT_INDEFINITELY。重复的间隔,必须是0,或者long型的正数,表示毫秒。注意,如果重复间隔为0,trigger将会以重复次数并发执行(或者以scheduler可以处理的近似并发数)。
endTime属性的值会覆盖设置重复次数的属性值;比如,你可以创建一个trigger,在终止时间之前每隔10秒执行一次,你不需要去计算在开始时间和终止时间之间的重复次数,只需要设置终止时间并将重复次数设置为REPEAT_INDEFINITELY(当然,你也可以将重复次数设置为一个很大的值,并保证该值比trigger在终止时间之前实际触发的次数要大即可)。
CronTrigger:基于日历的作业调度器。
Cron表达式:
用于配置CronTrigger实例。由7个子表达式组成的字符串,描述时间表的详细信息,格式:秒 分 时 日 月 周 年
Trigger trigger = TriggerBuilder.newTrigger().withIdentity("trigger")
.withSchedule(CronScheduleBuilder.cronSchedule("* * * * * ? *")).build();
通配符说明
实在是不知道怎么写 网上搜搜 cron在线生成表达式。