`
keyboardsun
  • 浏览: 56995 次
  • 性别: Icon_minigender_1
  • 来自: 上海
文章分类
社区版块
存档分类
最新评论

玩转 quartz quartz 教程 quartz 实现 quartz 封装

阅读更多

转载请表明出处,作者 keyboardsun

 

需要源代码,发邮件到keyboardsun@163.com

代码可以直接使用。

 

 

最近在开发JDF项目。项目中需要用到任务调度,自动任务等功能,想自己开发一个,但是看看 quartz    那么强劲,自己开发,开发加调试,可能需要些时日。如果用quartz可能一天就可以搞定,只需要配置点数据就可以了。

 

下面步入正题。讲解quartz的封装使用。

 

这里我把任务,以及任务的表达式配置到数据库里面。

 

如图:

 

如上图所示,配置了三个任务。

表结构介绍:

 

字段介绍:

TASK_ID 任务的主键

TASK_CODE 任务编码 ,这里启动任务的时候,作为qz任务的名称

TASK_TYPE_CODE 任务类型,这里启动任务的时候,作为qz任务的分组

TASK_IMPL_CLASS 任务的类。

TASK_EXPRESS 任务执行表达式

STATE_DATE 任务更新时间,这里在任务运行中,如果需要使运行中的任务修改立马生效,需要把这个字段的值设置大于当前时间。

STATE 任务状态

PARMS 任务初始化参数,任务运行的时候,可以从JobDataMap对象中获取该字段的值。

CREATE_DATE 创建日期,没有什么实际意义。

 

下面需要记录任务执行的日志,如下图所示

如上图所示,log编号是12 的任务正在执行中... STATE是R =run

字段解释

 

TASK_LOG_ID 任务日志编号

TASK_ID 任务编号

STATE 执行状态,如果是E 的,说明异常了,异常信息会放在REMARKS字段中

START_DATE 执行开始时间

FINISH_DATE 执行结束时间

REMARKS 备注。

 

下面要开始贴代码啦:如下图所示,一共包括如下这么多的JAVA文件。

 

一共包括文件为:

ITask.java 业务系统需要实现的接口方法。

JDBC.java 简单的数据库操作类

JobEngine 用于修改运行中的job的信息,定时扫描JOB_TASK配置表的改变信息。

JobTaskBean.java 表JOB_TASK对应的bean

Mouse.java 入口类,启动qz引擎。

Task.java 抽象类,用于记录qz 任务的日志,业务系统的任务需要继承这个类。

TaskLogBean.java 任务日志表TASK_LOG对应的Bean.

Test.java 测试任务。

 

下面开始贴代码啦:

ITask.java

 

JDBC.java

 

 

JobEngine.java

 

 

JobTaskBean.java

 

 

Mouse.java

 

 

Task.java

 

 

TaskLogBean.java

 

 

 

Test.java

 

 

下面我们在数据库里面添加两条任务。

 

INSERT INTO `job_task` VALUES ('1', 'TEST1', 'G1', 'net.chinacsharp.jdf.quartz.Test', '0/25 * * * * ?', '2009-07-09 16:48:00', 'U', '<item><key>sss</key><value>vvv</value></item><item><key>ss</key><value>vv</value></item>', null, '2009-07-07 16:07:41');
INSERT INTO `job_task` VALUES ('2', 'TEST2', 'G1', 'net.chinacsharp.jdf.quartz.Test', '0/20 * * * * ?', '2009-07-09 17:19:21', 'U', '<item><key>sss</key><value>vvv</value></item><item><key>ss</key><value>vv</value></item>', null, '2009-07-08 16:07:20');
INSERT INTO `job_task` VALUES ('3', 'TESTENGINE', 'ENG', 'net.chinacsharp.jdf.quartz.JobEngine', '0/7 * * * * ?', '2009-07-09 16:48:00', 'U', '<item><key>sss</key><value>vvv</value></item><item><key>ss</key><value>vv</value></item>', null, '2009-07-07 16:07:41');

 

这里的第三条任务是必须的。用于扫描JOB_TASK表的改动,及时把改动的部分覆盖到现有执行中的任务。

 

下面我们运行任务

 

 

我们查看日志信息

 

 

下面我们把执行的任务给改动下。

 

 

这里我把TASK_EXPRESS修改为 每秒执行1次,每2秒执行一次,然后把STATE_DATE的日期调整到迟与当前时间,这样JobEngine任务就可以扫描到改动了。下面我们看日志

如上所示,任务执行快多了噢。每秒就在执行。

 

下面我们察看执行的日志

 

 

下面我们自己开发一个任务把。如果你想自己开发一个任务,那么很简单,只需要两个步骤:

步骤一,新建一个类,继承Task.java实现execute(HashMap map)借口便可以

 

第二步:我们在表JOB_TASK配置任务。 这里把现有的人给改成不可用。减少日志输出,如下图

 

我们把1,2任务给关了,状态O了。把DEMO任务配置成每20秒执行一次。 PARMS字段为

<item><key>sss</key><value>vvv</value></item><item><key>ss</key><value>vv</value></item>

 

下面我们运行,察看日志:

 

这里20秒执行了一次,下面我们把任务的TASK_EXPRESS改成0/2 * * * * ?

 STATE_DATE 改成 2009-07-15 20:30:31

这样就两秒执行一次,我们看输出:

 

这里两秒执行一次了噢。

 

分享到:
评论
1 楼 keyboardsun 2009-11-19  
keyboardsun 发表于2009年7月10日 9:29:33  IP:举报删除
本文章对应的源代码请到 http://download.csdn.net/source/1477754 下载

相关推荐

Global site tag (gtag.js) - Google Analytics