Quartz使用之:HelloWorld

转:http://wangrui.iteye.com/blog/150704

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 

工程代码下载:http://download.csdn.net/detail/wxwzy738/6242299




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值