前序:
在第一个例子我看到了自定义的作业类在任务调度器上注册后,则通过任务调度器来实现启动;下面,我们将同一个作业类执行两个任务,并都将他们注册到任务调度器上!
首先一个job类指向两个任务,则任务性质可能一样,但任务信息存在差异;我们需要创建两个不同属性信息的job类实例;这个创建的动作是由Scheduler来完成;前面我们已经说了,它获取job信息并创建实例的前提操作如下:
JobDetail jobDetail = new JobDetail(jobName,Scheduler.DEFAULT_GROUP, jobClass);
jobDetail.getJobDataMap().put("SCAN_DIR", dirPath);
jobDetail.getJobDataMap().put("MATCH_NAME", matchName);
Trigger trigger=TriggerUtils.makeSecondlyTrigger(scanInterval);
trigger.setName(jobName + "-Trigger");
trigger.setStartTime(new Date());
scheduler.scheduleJob(jobDetail, trigger);
在注册后,任务调度器Scheduler就可以创建job实例,并执行execute操作了;
下面是我们在任务调度器上要求执行两个任务的代码:
/**
* 一个简短的作业调度器
* @author liuwei
*
*/
public class SimpleScheduler2 {
static Log logger = LogFactory.getLog(SimpleScheduler.class);
private Scheduler scheduler;
/**
* 调度器的启动操作
*/
public void startScheduler() {
try {
LogUtil.print("运行任务开始");
// 启动任务调度器
this.getScheduler().start();
/*将扫描目录的作业job注册到作业调度器上*/
this.registJobtoScheduler();
LogUtil.print("运行任务完毕");
} catch (SchedulerException ex) {
logger.error(ex);
}
}
/**
* 调度器的暂停操作
* @param scheduler
*/
public void modifyScheduler(Scheduler scheduler) {
try {
if (!scheduler.isInStandbyMode()) {
//暂停调度器,该任务调度器上所有的作业实例都将停止工作
scheduler.standby();
}
scheduler.start();
} catch (SchedulerException ex) {
logger.error(ex);
}
}
/**
* 注册一个作业到作业调度器
* @throws SchedulerException
* 注册一个作业到任务调度器上需要两个参数
* a.作业明细
* b.作业触发器
*/
public void registJobtoScheduler() throws SchedulerException{
LogUtil.print("将作业注册到调度器上");
//获取任务调度器实例
Scheduler scheduler=this.getScheduler();
//任务1的相关信息
String dirPath = "E:\\重要";
String matchName = ".rar";
String jobName="ScanDirectoryJob1";
//注册操作
this.registOperation(scheduler, jobName,
ScanDirectoryJob.class, 10, dirPath, matchName);
//任务2的相关信息
String dirPath1 = "E:\\重要";
String matchName2 = ".xls";
String jobName2="ScanDirectoryJob2";
//注册操作
this.registOperation(scheduler, jobName2,
ScanDirectoryJob.class, 10, dirPath1, matchName2);
}
/**
*根据任务调度器,作业名称,作业类,启动时间间隔,及作业信息
*注册两个作业任务到任务调度器上
*/
private void registOperation(Scheduler scheduler, String jobName,
Class jobClass, int scanInterval,String dirPath,String matchName )
{
try {
//创建任务的作业信息
//1)作业明细,作业数据集合,触发器
//2)根据作业明细,触发器来实现任务的注册
JobDetail jobDetail = new JobDetail
(jobName,Scheduler.DEFAULT_GROUP, jobClass);
jobDetail.getJobDataMap().put("SCAN_DIR", dirPath);
jobDetail.getJobDataMap().put("MATCH_NAME", matchName);
Trigger trigger = TriggerUtils.makeSecondlyTrigger
(scanInterval);
trigger.setName(jobName + "-Trigger");
trigger.setStartTime(new Date());
scheduler.scheduleJob(jobDetail, trigger);
} catch (SchedulerException e) {
e.printStackTrace();
}
}
/**
* 根据调度器工厂获得一个调度器
* @return
*/
private Scheduler getScheduler(){
Scheduler scheduler=null;
try {
LogUtil.print("获取任务调度器实例");
//根据调度器工厂获得一个任务调度器的实例
scheduler = StdSchedulerFactory.getDefaultScheduler();
}catch (SchedulerException ex) {
logger.error(ex);
}
return scheduler;
}
private void setScheduler(Scheduler scheduler){
his.scheduler=scheduler;
}
}
请大家关注一个点!!!
在 Scheduler 启动之前还是之后安排 Job 代码也就是任务调度器启动在先,还是说等所有工作在任务调度器上全部完成注册以后再开始启动呢?
实际上之前之后的效果是一样;我们可以认为:
a.若你先前启动,则当前作业还未在其上注册的话,启动后,任务调度器将处于等待状态,在(Job)作业在其上面进行注册后,则任务调度器将根据相关信息创建作业实例,并执行excute方法;
b.若在注册后执行start方法的话,则任务调度器将立即创建作业实例,并执行excute方法;
下面是两个任务同时执行的日志效果:
2009-02-02 22:35:05,468 [SimpleScheduler]-[DEBUG] 运行任务开始
2009-02-02 22:35:05,468 [SimpleScheduler]-[DEBUG] 将作业注册到调度器上
2009-02-02 22:35:05,468 [SimpleScheduler]-[DEBUG] 获取任务调度器实例
2009-02-02 22:35:05,781 [org.quartz.simpl.SimpleThreadPool]-[INFO] Job execution threads will use class loader of thread: main
2009-02-02 22:35:05,875 [org.quartz.core.SchedulerSignalerImpl]-[INFO] Initialized Scheduler Signaller of type: class org.quartz.core.SchedulerSignalerImpl
2009-02-02 22:35:05,890 [org.quartz.core.QuartzScheduler]-[INFO] Quartz Scheduler v.1.6.4 created.
2009-02-02 22:35:05,906 [org.quartz.simpl.RAMJobStore]-[INFO] RAMJobStore initialized.
2009-02-02 22:35:05,921 [org.quartz.impl.StdSchedulerFactory]-[INFO] Quartz scheduler 'DefaultQuartzScheduler' initialized from default resource file in Quartz package: 'quartz.properties'
2009-02-02 22:35:05,921 [org.quartz.impl.StdSchedulerFactory]-[INFO] Quartz scheduler version: 1.6.4
2009-02-02 22:35:06,000 [SimpleScheduler]-[DEBUG] 获取任务调度器实例
2009-02-02 22:35:06,000 [org.quartz.core.QuartzScheduler]-[INFO] Scheduler DefaultQuartzScheduler_$_NON_CLUSTERED started.
2009-02-02 22:35:06,000 [SimpleScheduler]-[DEBUG] 运行任务完毕
2009-02-02 22:35:06,015 [org.quartz.simpl.SimpleJobFactory]-[DEBUG] Producing instance of Job 'DEFAULT.ScanDirectoryJob1', class=ScanDirectoryJob
2009-02-02 22:35:06,015 [org.quartz.simpl.SimpleJobFactory]-[DEBUG] Producing instance of Job 'DEFAULT.ScanDirectoryJob2', class=ScanDirectoryJob
2009-02-02 22:35:06,015 [org.quartz.core.JobRunShell]-[DEBUG] Calling execute on job DEFAULT.ScanDirectoryJob1
2009-02-02 22:35:06,015 [ScanDirectoryJob]-[DEBUG] 作业任务名:ScanDirectoryJob1准备开始!
2009-02-02 22:35:06,015 [org.quartz.core.JobRunShell]-[DEBUG] Calling execute on job DEFAULT.ScanDirectoryJob2
2009-02-02 22:35:06,015 [ScanDirectoryJob]-[DEBUG] 作业任务名:ScanDirectoryJob2准备开始!
2009-02-02 22:35:06,109 [ScanDirectoryJob]-[DEBUG] 扫描符合条件的文件:E:\重要\CLPM绩效评价表(贷中组).xls - Size: 60416
2009-02-02 22:35:06,109 [ScanDirectoryJob]-[DEBUG] 扫描符合条件的文件:E:\重要\10月考核.rar - Size: 75058
2009-02-02 22:35:06,125 [ScanDirectoryJob]-[DEBUG] 扫描符合条件的文件:E:\重要\8月绩效.rar - Size: 86177
2009-02-02 22:35:06,125 [ScanDirectoryJob]-[DEBUG] 扫描符合条件的文件:E:\重要\贷中组5月考核.rar - Size: 77959
2009-02-02 22:35:06,125 [ScanDirectoryJob]-[DEBUG] 扫描符合条件的文件:E:\重要\贷中组6月考核.rar - Size: 32950
2009-02-02 22:35:06,125 [ScanDirectoryJob]-[DEBUG] 扫描符合条件的文件:E:\重要\贷中组7月考核.rar - Size: 32565
2009-02-02 22:35:06,125 [ScanDirectoryJob]-[DEBUG] 扫描符合条件的文件:E:\重要\刘伟出差借款表.xls - Size: 10752
2009-02-02 22:35:06,125 [ScanDirectoryJob]-[DEBUG] 扫描符合条件的文件:E:\重要\开发任务跟踪表.xls - Size: 687616
2009-02-02 22:35:06,125 [ScanDirectoryJob]-[DEBUG] 扫描符合条件的文件:E:\重要\机票(刘伟).xls - Size: 13312
2009-02-02 22:35:06,125 [ScanDirectoryJob]-[DEBUG] 作业任务名:ScanDirectoryJob2操作完毕!
2009-02-02 22:35:06,125 [ScanDirectoryJob]-[DEBUG] 作业任务名:ScanDirectoryJob1操作完毕!
2009-02-02 22:35:15,984 [org.quartz.simpl.SimpleJobFactory]-[DEBUG] Producing instance of Job 'DEFAULT.ScanDirectoryJob1', class=ScanDirectoryJob
2009-02-02 22:35:15,984 [org.quartz.core.JobRunShell]-[DEBUG] Calling execute on job DEFAULT.ScanDirectoryJob1
2009-02-02 22:35:15,984 [ScanDirectoryJob]-[DEBUG] 作业任务名:ScanDirectoryJob1准备开始!
2009-02-02 22:35:16,000 [ScanDirectoryJob]-[DEBUG] 扫描符合条件的文件:E:\重要\10月考核.rar - Size: 75058
2009-02-02 22:35:16,000 [ScanDirectoryJob]-[DEBUG] 扫描符合条件的文件:E:\重要\8月绩效.rar - Size: 86177
2009-02-02 22:35:16,000 [ScanDirectoryJob]-[DEBUG] 扫描符合条件的文件:E:\重要\贷中组5月考核.rar - Size: 77959
2009-02-02 22:35:16,000 [ScanDirectoryJob]-[DEBUG] 扫描符合条件的文件:E:\重要\贷中组6月考核.rar - Size: 32950
2009-02-02 22:35:16,000 [ScanDirectoryJob]-[DEBUG] 扫描符合条件的文件:E:\重要\贷中组7月考核.rar - Size: 32565
2009-02-02 22:35:16,000 [ScanDirectoryJob]-[DEBUG] 作业任务名:ScanDirectoryJob1操作完毕!
2009-02-02 22:35:16,000 [org.quartz.simpl.SimpleJobFactory]-[DEBUG] Producing instance of Job 'DEFAULT.ScanDirectoryJob2', class=ScanDirectoryJob
2009-02-02 22:35:16,000 [org.quartz.core.JobRunShell]-[DEBUG] Calling execute on job DEFAULT.ScanDirectoryJob2
2009-02-02 22:35:16,000 [ScanDirectoryJob]-[DEBUG] 作业任务名:ScanDirectoryJob2准备开始!
2009-02-02 22:35:16,015 [ScanDirectoryJob]-[DEBUG] 扫描符合条件的文件:E:\重要\CLPM绩效评价表(贷中组).xls - Size: 60416
2009-02-02 22:35:16,015 [ScanDirectoryJob]-[DEBUG] 扫描符合条件的文件:E:\重要\刘伟出差借款表.xls - Size: 10752
2009-02-02 22:35:16,015 [ScanDirectoryJob]-[DEBUG] 扫描符合条件的文件:E:\重要\开发任务跟踪表.xls - Size: 687616
2009-02-02 22:35:16,015 [ScanDirectoryJob]-[DEBUG] 扫描符合条件的文件:E:\重要\机票(刘伟).xls - Size: 13312
2009-02-02 22:35:16,015 [ScanDirectoryJob]-[DEBUG] 作业任务名:ScanDirectoryJob2操作完毕!
2009-02-02 22:35:25,984 [org.quartz.simpl.SimpleJobFactory]-[DEBUG] Producing instance of Job 'DEFAULT.ScanDirectoryJob1', class=ScanDirectoryJob
2009-02-02 22:35:25,984 [org.quartz.core.JobRunShell]-[DEBUG] Calling execute on job DEFAULT.ScanDirectoryJob1
2009-02-02 22:35:25,984 [ScanDirectoryJob]-[DEBUG] 作业任务名:ScanDirectoryJob1准备开始!
2009-02-02 22:35:26,000 [ScanDirectoryJob]-[DEBUG] 扫描符合条件的文件:E:\重要\10月考核.rar - Size: 75058
2009-02-02 22:35:26,000 [ScanDirectoryJob]-[DEBUG] 扫描符合条件的文件:E:\重要\8月绩效.rar - Size: 86177
2009-02-02 22:35:26,000 [ScanDirectoryJob]-[DEBUG] 扫描符合条件的文件:E:\重要\贷中组5月考核.rar - Size: 77959
2009-02-02 22:35:26,000 [ScanDirectoryJob]-[DEBUG] 扫描符合条件的文件:E:\重要\贷中组6月考核.rar - Size: 32950
2009-02-02 22:35:26,000 [ScanDirectoryJob]-[DEBUG] 扫描符合条件的文件:E:\重要\贷中组7月考核.rar - Size: 32565
2009-02-02 22:35:26,000 [ScanDirectoryJob]-[DEBUG] 作业任务名:ScanDirectoryJob1操作完毕!
2009-02-02 22:35:26,015 [org.quartz.simpl.SimpleJobFactory]-[DEBUG] Producing instance of Job 'DEFAULT.ScanDirectoryJob2', class=ScanDirectoryJob
2009-02-02 22:35:26,015 [org.quartz.core.JobRunShell]-[DEBUG] Calling execute on job DEFAULT.ScanDirectoryJob2
2009-02-02 22:35:26,015 [ScanDirectoryJob]-[DEBUG] 作业任务名:ScanDirectoryJob2准备开始!
2009-02-02 22:35:26,015 [ScanDirectoryJob]-[DEBUG] 扫描符合条件的文件:E:\重要\CLPM绩效评价表(贷中组).xls - Size: 60416
2009-02-02 22:35:26,015 [ScanDirectoryJob]-[DEBUG] 扫描符合条件的文件:E:\重要\刘伟出差借款表.xls - Size: 10752
2009-02-02 22:35:26,015 [ScanDirectoryJob]-[DEBUG] 扫描符合条件的文件:E:\重要\开发任务跟踪表.xls - Size: 687616
2009-02-02 22:35:26,015 [ScanDirectoryJob]-[DEBUG] 扫描符合条件的文件:E:\重要\机票(刘伟).xls - Size: 13312
2009-02-02 22:35:26,015 [ScanDirectoryJob]-[DEBUG] 作业任务名:ScanDirectoryJob2操作完毕!
分享到:
相关推荐
Spring整合任务调度框架Quartz,本文档详细介绍了Spring整合任务调度框架Quartz,希望可以帮助学习者
Java任务调度框架Quartz2.0.2(版本:2.0.2)教程实例源代码
任务调度框架Quartz, 任务调度框架Quartz, 任务调度框架Quartz
Quartz框架是一个全功能、开源的任务调度服务,可以集成几乎任何的java应用程序—从小的单片机系统到大型的电子商务系统。Quartz可以执行上千上万的任务调度
Java任务调度框架Quartz1.8.6(版本:1.8.6)教程实例源代码
LTS是一个轻量级分布式任务调度框架。有三种角色, JobClient, JobTracker, TaskTracker。 4. uncode-schedule 基于zookeeper+spring task的分布式任务调度组件,非常小巧,无需任何修改就可以使spring task具备...
Quartz.net作业调度自定义定时执行任务多任务执行c#,定时执行任务,如超时取消订单,自动确认收货等等
NULL 博文链接:https://baobeituping.iteye.com/blog/629237
任务调度Quartz框架 任务调度Quartz框架
Quartz-2.2.1 任务调度框架在Java项目中的使用实例 Demo 在这个小Demo 中使用了Java 类的反射机制,通用的项目实例,高度抽象的实例。 在业务需求不是很复杂的情况下,完全可以减少因为使用Quartz任务调度框架的代码...
Quartz-2.2.1 任务调度框架在Java项目中的使用实例 Demo 在这个小Demo 中使用了Java 类的反射机制,通用的项目实例,高度抽象的实例。 在业务需求不是很复杂的情况下,完全可以减少因为使用Quartz任务调度框架的代码...
任务调度框架Quartz[收集].pdf
Quartz任务调度框架教程中文版 chm格式
spring quartz 时间任务调度框架 spring quartz 时间任务调度框架 spring quartz 时间任务调度框架
Quartz是功能强大的开源作业调度库,几乎可以集成到任何Java应用程序中-从最小的独立应用程序到最大的电子商务系统。Quartz可用于创建简单或复杂的计划,以执行数以万计,数以万计的工作;任务定义为标准Java组件的...
quartz定时调度完整实例 完美调度quartz定时调度完整实例 完美调度
Quartz 是个开源的作业调度框架,为在 Java 应用程序中进行作业调度提供了简单却强大的机制。Quartz框架包含了调度器监听、作业和触发器监听。你可以配置作业和触发器监听为全局监听或者是特定于作业和触发器的监听...
spring任务调度(Quartz )非常基础,
使用Quartz调度任务,根据需要人为的终止某个任务,适用于很多常见的场景