`
wangrui
  • 浏览: 186629 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Quartz使用之:HelloWorld

阅读更多
1.目的:
 
怎样创建、开始、暂停、关闭Quartz的scheduler?怎样用Quartz执行一个定时任务?

2.HelloWorld任务。

Quartz中的任务必须实现org.quartz.Job接口,
public interface Job {
      void execute(JobExecutionContext context) throws JobExecutionException;
}


该接口只有一个execute方法。子类中实现该方法包含我们要定时执行的任务代码.

HelloWorldJob.java


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());
	}

}


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

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();
	}

}


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
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics