Quratz

1. Job

import org.quartz.Job;
import org.quartz.JobDataMap;
import org.quartz.JobDetail;
import org.quartz.JobExecutionContext;
import org.quartz.JobExecutionException;
import org.quartz.Trigger;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

public class HelloJob implements Job {
	
	private static final Logger logger = LoggerFactory.getLogger(HelloJob.class);

	@Override
	public void execute(JobExecutionContext context) throws JobExecutionException {
		logger.info("### HelloJob execute ...");

		JobDetail jobDetail = context.getJobDetail();
		Trigger trigger = context.getTrigger();
		
		JobDataMap jobDataMap = jobDetail.getJobDataMap();
		JobDataMap triJobDataMap = trigger.getJobDataMap();
		JobDataMap mergedJobDataMap = context.getMergedJobDataMap();
		
		String jobName = jobDataMap.getString("jobName");
		String triName = triJobDataMap.getString("triName");
		// 公共key从merge job data获取数据得到trigger中的
		String key = mergedJobDataMap.getString("key");
		
		logger.info("jobName: {}", jobName);
		logger.info("triName: {}", triName);
		logger.info("key: {}", key);
	}

}

2. 任务调度

public void quartz() {

    try {
        // Grab the Scheduler instance from the Factory
	Scheduler scheduler = StdSchedulerFactory.getDefaultScheduler();
	// and start it off
	scheduler.start();

	// define the job and tie it to our HelloJob class
	JobDetail job = JobBuilder.newJob(HelloJob.class).withIdentity("job1", "group1")
			.usingJobData("jobName", "jobQuartz").usingJobData("key", "jobDetail").build();

	// Trigger the job to run now, and then repeat every 40 seconds
	Trigger trigger = TriggerBuilder.newTrigger().withIdentity("trigger1", "group1").startNow()
			.withSchedule(SimpleScheduleBuilder.simpleSchedule().withIntervalInSeconds(5).repeatForever())
			.usingJobData("triName", "triQuartz").usingJobData("key", "trigger").build();

	// Tell quartz to schedule the job using our trigger
	scheduler.scheduleJob(job, trigger);

	// scheduler.shutdown();
    } catch (SchedulerException e) {
	e.printStackTrace();
    }

}

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值