使用spring quartz 进行持久化的任务调度

从quartz的发布包中找到docs/dbTables/目录下的sql脚本,创建数据库表。

applicationContext.xml的配置

<bean id="schedulerFactory"
		class="org.springframework.scheduling.quartz.SchedulerFactoryBean">
		<property name="dataSource" ref="dataSource"></property>
	</bean>

package com.wxl.app.quartz;

import java.util.Map;

import org.quartz.JobExecutionContext;
import org.quartz.JobExecutionException;
import org.quartz.StatefulJob;

public class PersistentJob implements StatefulJob {
	public PersistentJob() {
		System.out.println("PersistentJob");
	}

	public void execute(JobExecutionContext jc) throws JobExecutionException {
		Map map = jc.getJobDetail().getJobDataMap();
		System.out.println("[" + jc.getJobDetail().getName() + "]"
				+ map.get("message"));
	}

}

package com.wxl.app.quartz;

import java.util.Calendar;

import org.quartz.JobDetail;
import org.quartz.Scheduler;
import org.quartz.SchedulerException;
import org.quartz.SimpleTrigger;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

public class SpringWithJobPersistence {
	public static void main(String[] args) throws SchedulerException {
		ApplicationContext ac = new ClassPathXmlApplicationContext(
				"applicationContext.xml");
		Scheduler scheduler = (Scheduler) ac.getBean("schedulerFactory");
		JobDetail jobDetail = new JobDetail("job1", PersistentJob.class);
		JobDetail jobDetail2 = new JobDetail("job2", PersistentJob.class);
		jobDetail.getJobDataMap().put("message", "aaa");
		Calendar cal = Calendar.getInstance();
		cal.add(Calendar.MINUTE, 1);
		scheduler.scheduleJob(jobDetail, new SimpleTrigger("simpleTrigger1",
				Scheduler.DEFAULT_GROUP, cal.getTime(), null, 0, 15000));

		jobDetail2.getJobDataMap().put("message", "bbb");
		scheduler.scheduleJob(jobDetail2, new SimpleTrigger("simpleTrigger2",
				Scheduler.DEFAULT_GROUP, cal.getTime(), null, 0, 15000));
	}
}


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值