quartz的使用以及web應用的任務調度

在工作中不可避免會遇到任務調度的場景,無論是積分統計,生成報表,用戶管理等都需要在某個時間節點進行相應的業務操作,而JDK中的Time和TimerTask適用場景偏向於持續時間短,簡單重複的操作。因此針對時間跨度長,自定義時間觸發的調度場景,更適合適用Quartz框架。以下便是Quartz的入門講解以及使用:

Quartz基礎結構:

1.      Job:是一個只有voidexecute(JobExecutionContext context)方法的接口,開發者通過實現接口,在方法中定義需要完成的任務,context提供調度上下文的信息。

2.      JobDetail:接收一個Job實現類,通過反射機制實例化Job。且每次執行Job,都會重新創建一個Job實例。因此這個類用於描述Job實現類和其他靜態信息,以便實例化操作。

3.      Trigger:代表觸發Job執行的規則。主要有SimpleTrigger和CronTrigger兩個子類。

4.      Calendar:代表日期集合,可以與Trigger關聯,以便在常規規則中取出某些特殊時間點。

5.      Scheduler:Quartz的獨立運行容器,JobDetail和Trigger註冊到Scheduler內,以實現Trigger和Job的關聯。Trigger和Jobdetai各自的名稱和組名的組合是Scheduler的唯一標示,因此必須唯一(但是對於一個Trigger和一個Jobdetail,名稱和組名不相關,因爲在不同的集合內)一個Job可以對應多個Trigger而一個Trigger只能對應一個Job。


Job實例:

public class DealDataJob implements Job{

	private static final Logger log = Logger.getLogger(DealDataJob.class);
	@Override
	public void execute(JobExecutionContext context) throws JobExecutionException {
		log.info("--------------");
		log.info("預處理數據...");
		RecordDao recordDao = new RecordDao();
		recordDao.preDealData();
		recordDao = null;
		log.info(new Date());
		log.info("處理數據結束");
		log.info("--------------");
	}

}
配置Scheduler:

public class QuartzManage {

	private static final Logger log = Logger.getLogger(QuartzManage.class);
	private static final String JOB_NAME = "deal_data";
	private static final String GROUP_NAME = "group";
	private static final String TRIGGER_NAME = "daily";
	
	
	public static void manageJob() {
		try {
			JobDetail jobDetail = configJobDetail();
			CronTrigger cronTrigger = configTrigger();
			Scheduler scheduler = configScheduler(jobDetail, cronTrigger);
			scheduler.start();
		} catch (Exception e) {
			e.printStackTrace();
			log.info("manage failed");
			log.error(e.getMessage());
		}
	}
	
	/**
	 * 配置JobDetail
	 * @return
	 */
	private static JobDetail configJobDetail(){
		JobDetailImpl jobDetail = new JobDetailImpl();
		jobDetail.setName(JOB_NAME);
		jobDetail.setGroup(GROUP_NAME);
		jobDetail.setJobClass(DealDataJob.class);
		return jobDetail;
	}
	
	/**
	 * 配置調度時間點Trigger
	 * @return
	 * @throws ParseException
	 */
	private static CronTrigger configTrigger() throws ParseException{
		CronTriggerImpl cronTrigger = new CronTriggerImpl();
		cronTrigger.setName(TRIGGER_NAME);
		cronTrigger.setGroup(GROUP_NAME);
		CronExpression expression = new CronExpression("0 0 6 * * ? *");	//每天早上六點觸發操作
		cronTrigger.setCronExpression(expression);
		return cronTrigger;
	}
	
	/**
	 * 配置運行容器,並將工作和調度時間註冊到運行容器中
	 * @param jobDetail
	 * @param trigger
	 * @return
	 * @throws SchedulerException
	 */
	private static Scheduler configScheduler(JobDetail jobDetail,Trigger trigger) 
			throws SchedulerException{
		SchedulerFactory schedulerFactory = new StdSchedulerFactory();
		Scheduler scheduler = schedulerFactory.getScheduler();
		scheduler.scheduleJob(jobDetail, trigger);
		return scheduler;
	}
	
	public static void main(String[]args){
		manageJob();
	}


在Web應用中,只需要定義一個Listener,配置到web.xml中。調用Quartz即可完成任務調度:

public class ContextListener implements ServletContextListener{

	@Override
	public void contextDestroyed(ServletContextEvent sce) {
		// TODO Auto-generated method stub
		System.out.println("context destroyed");
	}

	@Override
	public void contextInitialized(ServletContextEvent sce) {
		// TODO Auto-generated method stub
		System.out.println("context initialized");
		QuartzManage.manageJob();
	}

}
web.xml

<listener>
    <listener-class>
        com.bydota.product.listener.ContextListener
    </listener-class>
  </listener>



發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章