Quartz:是一个定时任务调度框架。
比如遇到问题:
1.想在30分钟后,查看订单是否支付,未支付则取消订单
2.想在每个月29号,信用卡自动还款
…
想定时在某个事件,去做某件事(任务)
Quartz是要做定时任务的调度,设置好触发时间,以及相应的任务(job)即可
Quartz使用步骤
1.导入依赖
<!-- https://mvnrepository.com/artifact/org.quartz-scheduler/quartz -->
<dependency>
<groupId>org.quartz-scheduler</groupId>
<artifactId>quartz</artifactId>
<version>2.2.3</version>
</dependency>
2.定义一个Job任务实现Job接口
public class HelloJob implements Job {
public void execute(JobExecutionContext jobExecutionContext) throws JobExecutionException {
JobDetail jobDetail = jobExecutionContext.getJobDetail();
JobKey key = jobDetail.getKey(); //获取JobDetail的名字 和分组
System.out.println(key.getName());//任务名字
System.out.println(key.getGroup());//任务的分组
System.out.println("hello job exec"+new Date());
}
}
3. 在主方法中定义调度器,触发器,JobDetail
3.1 新建一个调取器调度器
StdScheduler scheduler = StdSchedulerFactory.getDefaultScheduler();
3.2触发器
SimpleTrigger build = TriggerBuilder.newTrigger().withIdentity("trigger1", "group1")
.startNow()//起始时间
.withSchedule(SimpleScheduleBuilder.simpleSchedule()
.withIntervalInSeconds(2)//每多少秒执行一次
.repeatForever()) //不限定执行次数
.endAt(new GregorianCalendar(2020, 5, 2, 12, 22, 0).getTime())//截止时间
.build();
3.3 获取JobDetail对象
JobDetail JobDetail = JobBuilder.newJob(HelloJob.class).withIdentity("job1", "group1").build();
3.4.将JobDetail 和 触发器增加到调度器中
scheduler.scheduleJob(JobDetail,build);
3.5 启动,调度器开始工作
scheduler.start();
4.Quartz配置
名为quertz.properties,放置在classpath下,如果没有此配置就默认配置启动
#指定调度器名称,非实现类
org.quartz.scheduler.instanceName = DefaultQuartzScheduler
# 指定线程池实现类
org.quartz.threadPool.class = org.quartz.simpl.SimpleThreadPool
# 线程池线程数量
org.quartz.threadPool.threadCount = 10
# 优先级,默认5
org.quartz.threadPool.threadPriority = 5
# 非持久化job
org.quartz.jobStore.class = org.quartz.simpl.RAMJobStore
核心类的说明
**1.Scheduler:**调度器。所有的调度都是由它控制,是Quartz的大脑,所有任务都是由它来管理的
**2.Job:**任务。想定时执行的事情定义业务逻辑
**3.JobDetail:**基于Job,进一步包装,其中关联一个Job,并为Job指定更详细的属性,比如标识等
**4.Trigger:**触发器,可以指定给某个任务,指定任务的触发机制
Trigger:触发器
1.SimpleTrigger
以一定的时间间隔(单位是毫秒)执行的任务
1.指定起始和截止时间(时间段)
2.指定时间间隔。执行次数
SimpleTrigger build = TriggerBuilder.newTrigger().withIdentity("trigger1", "group1")
.startNow()//起始时间
.withSchedule(SimpleScheduleBuilder