1.目的:
怎样创建、开始、暂停、关闭Quartz的scheduler?怎样用Quartz执行一个定时任务?
2.HelloWorld任务。
Quartz中的任务必须实现org.quartz.Job接口,
[code]
public interface Job {
void execute(JobExecutionContext context) throws JobExecutionException;
}
[/code]
该接口只有一个execute方法。子类中实现该方法包含我们要定时执行的任务代码.
HelloWorldJob.java
[code]
package lab.quartz.lab01;
import java.util.Date;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.quartz.Job;
import org.quartz.JobExecutionContext;
import org.quartz.JobExecutionException;
/**
* <p>
* This is just a simple job that says "Hello,World!".
* </p>
*
*/
public class HelloWorldJob implements Job {
Log log = LogFactory.getLog(HelloWorldJob.class);
public void execute(JobExecutionContext arg0) throws JobExecutionException {
log.info("Hello World!,执行时间:"+new Date());
}
}
[/code]
3.定时执行HelloWorld任务
a.创建Scheduler,我们可以从一个SchedulerFactory类取得Scheduler对象。
SchedulerFactory sf = new StdSchedulerFactory();
Scheduler sched = sf.getScheduler();
b.构造HelloWorldJob的JobDetail对象
JobDetail jd = new JobDetail("Hello",Scheduler.DEFAULT_GROUP,HelloWorldJob.class);
c.构造HelloWorldJob的触发器对象
//每隔1分钟执行一次
Trigger tg = TriggerUtils.makeMinutelyTrigger(1);
触发器必须有名称。
tg.setName("HelloTrigger");
d.安排任务
sch.scheduleJob(jd, tg);
e.开始Scheduler,
当Scheduler被创建后,处于"stand-by"模式,不会触发任务。调用Scheduler的start()方法开始Scheduler,会触发任务的执行。
sch.start();
f.暂停Scheduler,调用standby(),使Scheduler回到"stand-by"模式。再次调用start()方法,使Scheduler回到运行状态。
sch.standby();
g.停止Scheduler,停止后不能重新开始。
sch.shutdown(true);
HelloWorldMain.java
[code]
package lab.quartz.lab01;
import java.util.Date;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.quartz.JobDetail;
import org.quartz.Scheduler;
import org.quartz.SchedulerFactory;
import org.quartz.Trigger;
import org.quartz.TriggerUtils;
import org.quartz.impl.StdSchedulerFactory;
/**
* 演示怎样开始、暂停、关闭Quartz的scheduler?怎样在Quartz中安排一个定时任务?
*
* @author wangrui
*
*/
public class HelloWorldMain {
Log log = LogFactory.getLog(HelloWorldMain.class);
public void run() {
try {
//取得Schedule对象
SchedulerFactory sf = new StdSchedulerFactory();
Scheduler sch = sf.getScheduler();
//构造JobDetail对象
JobDetail jd = new JobDetail("HelloWorldJobDetail",Scheduler.DEFAULT_GROUP,HelloWorldJob.class);
//构造触发器对象
Trigger tg = TriggerUtils.makeMinutelyTrigger(1);
tg.setName("HelloWorldTrigger");
sch.scheduleJob(jd, tg);
//开始Scheduler
sch.start();
log.info("Scheduler开始。开始时间:"+new Date());
Thread.sleep(120000);
//开始Scheduler
sch.standby();
log.info("Scheduler暂停。暂停时间:"+new Date());
Thread.sleep(120000);
//重新开始Scheduler
sch.start();
log.info("Scheduler重新开始。开始时间:"+new Date());
Thread.sleep(120000);
sch.shutdown(true);
log.info("Scheduler停止。停止时间:"+new Date());
} catch ( Exception e ) {
e.printStackTrace();
}
}
public static void main(String[] args) {
HelloWorldMain hw = new HelloWorldMain();
hw.run();
}
}
[/code]
4.执行结果
[INFO] 25 十二月 02:13:45.578 下午 main [lab.quartz.lab01.HelloWorldMain]
Scheduler开始。开始时间:Tue Dec 25 14:13:45 CST 2007
[INFO] 25 十二月 02:13:45.625 下午 DefaultQuartzScheduler_Worker-1 [lab.quartz.lab01.HelloWorldJob]
Hello World!,执行时间:Tue Dec 25 14:13:45 CST 2007
[INFO] 25 十二月 02:14:45.640 下午 DefaultQuartzScheduler_Worker-2 [lab.quartz.lab01.HelloWorldJob]
Hello World!,执行时间:Tue Dec 25 14:14:45 CST 2007
[INFO] 25 十二月 02:15:45.578 下午 main [lab.quartz.lab01.HelloWorldMain]
Scheduler暂停。暂停时间:Tue Dec 25 14:15:45 CST 2007
[INFO] 25 十二月 02:17:45.593 下午 main [lab.quartz.lab01.HelloWorldMain]
Scheduler重新开始。开始时间:Tue Dec 25 14:17:45 CST 2007
[INFO] 25 十二月 02:18:45.593 下午 DefaultQuartzScheduler_Worker-3 [lab.quartz.lab01.HelloWorldJob]
Hello World!,执行时间:Tue Dec 25 14:18:45 CST 2007
[INFO] 25 十二月 02:19:45.593 下午 main [lab.quartz.lab01.HelloWorldMain]
Scheduler停止。停止时间:Tue Dec 25 14:19:45 CST 2007
怎样创建、开始、暂停、关闭Quartz的scheduler?怎样用Quartz执行一个定时任务?
2.HelloWorld任务。
Quartz中的任务必须实现org.quartz.Job接口,
[code]
public interface Job {
void execute(JobExecutionContext context) throws JobExecutionException;
}
[/code]
该接口只有一个execute方法。子类中实现该方法包含我们要定时执行的任务代码.
HelloWorldJob.java
[code]
package lab.quartz.lab01;
import java.util.Date;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.quartz.Job;
import org.quartz.JobExecutionContext;
import org.quartz.JobExecutionException;
/**
* <p>
* This is just a simple job that says "Hello,World!".
* </p>
*
*/
public class HelloWorldJob implements Job {
Log log = LogFactory.getLog(HelloWorldJob.class);
public void execute(JobExecutionContext arg0) throws JobExecutionException {
log.info("Hello World!,执行时间:"+new Date());
}
}
[/code]
3.定时执行HelloWorld任务
a.创建Scheduler,我们可以从一个SchedulerFactory类取得Scheduler对象。
SchedulerFactory sf = new StdSchedulerFactory();
Scheduler sched = sf.getScheduler();
b.构造HelloWorldJob的JobDetail对象
JobDetail jd = new JobDetail("Hello",Scheduler.DEFAULT_GROUP,HelloWorldJob.class);
c.构造HelloWorldJob的触发器对象
//每隔1分钟执行一次
Trigger tg = TriggerUtils.makeMinutelyTrigger(1);
触发器必须有名称。
tg.setName("HelloTrigger");
d.安排任务
sch.scheduleJob(jd, tg);
e.开始Scheduler,
当Scheduler被创建后,处于"stand-by"模式,不会触发任务。调用Scheduler的start()方法开始Scheduler,会触发任务的执行。
sch.start();
f.暂停Scheduler,调用standby(),使Scheduler回到"stand-by"模式。再次调用start()方法,使Scheduler回到运行状态。
sch.standby();
g.停止Scheduler,停止后不能重新开始。
sch.shutdown(true);
HelloWorldMain.java
[code]
package lab.quartz.lab01;
import java.util.Date;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.quartz.JobDetail;
import org.quartz.Scheduler;
import org.quartz.SchedulerFactory;
import org.quartz.Trigger;
import org.quartz.TriggerUtils;
import org.quartz.impl.StdSchedulerFactory;
/**
* 演示怎样开始、暂停、关闭Quartz的scheduler?怎样在Quartz中安排一个定时任务?
*
* @author wangrui
*
*/
public class HelloWorldMain {
Log log = LogFactory.getLog(HelloWorldMain.class);
public void run() {
try {
//取得Schedule对象
SchedulerFactory sf = new StdSchedulerFactory();
Scheduler sch = sf.getScheduler();
//构造JobDetail对象
JobDetail jd = new JobDetail("HelloWorldJobDetail",Scheduler.DEFAULT_GROUP,HelloWorldJob.class);
//构造触发器对象
Trigger tg = TriggerUtils.makeMinutelyTrigger(1);
tg.setName("HelloWorldTrigger");
sch.scheduleJob(jd, tg);
//开始Scheduler
sch.start();
log.info("Scheduler开始。开始时间:"+new Date());
Thread.sleep(120000);
//开始Scheduler
sch.standby();
log.info("Scheduler暂停。暂停时间:"+new Date());
Thread.sleep(120000);
//重新开始Scheduler
sch.start();
log.info("Scheduler重新开始。开始时间:"+new Date());
Thread.sleep(120000);
sch.shutdown(true);
log.info("Scheduler停止。停止时间:"+new Date());
} catch ( Exception e ) {
e.printStackTrace();
}
}
public static void main(String[] args) {
HelloWorldMain hw = new HelloWorldMain();
hw.run();
}
}
[/code]
4.执行结果
[INFO] 25 十二月 02:13:45.578 下午 main [lab.quartz.lab01.HelloWorldMain]
Scheduler开始。开始时间:Tue Dec 25 14:13:45 CST 2007
[INFO] 25 十二月 02:13:45.625 下午 DefaultQuartzScheduler_Worker-1 [lab.quartz.lab01.HelloWorldJob]
Hello World!,执行时间:Tue Dec 25 14:13:45 CST 2007
[INFO] 25 十二月 02:14:45.640 下午 DefaultQuartzScheduler_Worker-2 [lab.quartz.lab01.HelloWorldJob]
Hello World!,执行时间:Tue Dec 25 14:14:45 CST 2007
[INFO] 25 十二月 02:15:45.578 下午 main [lab.quartz.lab01.HelloWorldMain]
Scheduler暂停。暂停时间:Tue Dec 25 14:15:45 CST 2007
[INFO] 25 十二月 02:17:45.593 下午 main [lab.quartz.lab01.HelloWorldMain]
Scheduler重新开始。开始时间:Tue Dec 25 14:17:45 CST 2007
[INFO] 25 十二月 02:18:45.593 下午 DefaultQuartzScheduler_Worker-3 [lab.quartz.lab01.HelloWorldJob]
Hello World!,执行时间:Tue Dec 25 14:18:45 CST 2007
[INFO] 25 十二月 02:19:45.593 下午 main [lab.quartz.lab01.HelloWorldMain]
Scheduler停止。停止时间:Tue Dec 25 14:19:45 CST 2007