下面是之前项目中quartz的运用,我将它梳理出来。

测试类:

public class OrdExpireTaskMain {
public static void main(String[] args) {
String[]agrs=new String[]{"EXPIRE_TASK_571_CS","1","0"};
try {
TaskFrameWork.main(agrs);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}

上面的测试类一个参数是CFG_TASK_TYPE_CODE,第二个取模,第三个是根据值进行取模,通过调用框架的main函数,来执行调度任务。

1:首先根据先获取任务的一个配置文件,通过配置文件我们可以更灵活。比如可以配置调度表达式,名称等
代码片段

  Properties prop = ResourceUtil.loadPropertiesFromClassPath("task/task.properties", "task", true);
if ((!(StringUtils.isBlank(prop.getProperty("bootPauseSeconds"))))&& (StringUtils.isNumeric(prop.getProperty("bootPauseSeconds"))))
{
bootPauseSeconds = Long.parseLong(prop.getProperty("bootPauseSeconds").trim());
}

注:bootPauseSeconds 是当前任务启动暂停时间
2:new StdSchedulerFactory(prop)一个 对象,
根据这个对象get一个调度实例(scheduler)
    -----> 然后设置任务明细(JobDetail),调度策略(Trigger)
    ----->然后启动任务(start)
    ----->sleep当前线程
3:这个调度的实现类是TaskScanJob
taskScanJob:这个任务类是从csf_task 表中取出任务数据
代码片段

            JobDataMap data = context.getJobDetail().getJobDataMap();

            String taskType = data.getString("TASK_TYPE");
long mod = data.getLong("DATASPLIT_MOD");
long value = data.getLong("DATASPLIT_VALUE"); ITaskSV objITaskSV = (ITaskSV)ServiceFactory.getService(ITaskSV.class);
IBOCfgTaskValue[] objIBOCfgTaskValue = objITaskSV.getCfgTaskByTaskType(taskType, mod, value);

判断当前是否还有任务在执行,根据当前任务的任务名称和任务组名称,如果相等就是有任务上次扫描的任务在执行,就等待这次扫描的任务执行完。

如果不相等就在之前的context重置他的scheduler 调度任务,创建过程:
(1)创建JobDetail, jobDetail 的任务类是taskJob.class
(2)创建Trigger 首先取出csgTaskValue中的taskMethod,判断如果是C,就创建CronTrigger;如果不是就创建SimpleTrigger
(3)在当前的jobDataMap中put  TASK_CFG_ID
(4)重置调度任务

taskJob.class 类是处理cfgTaskValue的类,也是调度我们处理任务的真正实现类
(1)取出 TASK_CFG_ID 的id,查出cfgTaskValue,cfgTaskValue 就是保存处理数据的value。首先记录value的日志。
(2)根据value的businessClass,获取class的实例
(3)调用业务类的doTask
(4)并将task的执行结果update到日志表中

quartz项目中的运用的更多相关文章

  1. 项目中使用Quartz集群分享--转载

    项目中使用Quartz集群分享--转载 在公司分享了Quartz,发布出来,希望大家讨论补充. CRM使用Quartz集群分享  一:CRM对定时任务的依赖与问题  二:什么是quartz,如何使用, ...

  2. 初识quartz 并分析 项目中spring整合quartz的配置【原创+转载】

    初识quartz 并分析 项目中spring整合quartz的配置[原创+转载]2018年01月29日 12:08:07 守望dfdfdf 阅读数:114 标签: quartz 更多个人分类: 工具 ...

  3. 在springboot项目中引入quartz任务调度器。

    quartz是一个非常强大的任务调度器.我们可能使用它来管理我们的项目,常见的是做业绩统计等等.当然它的功能远不止这些.我们在这里不介绍quartz的原理,下面讲讲如何在springboot中使用qu ...

  4. spring项目中使用定时任务

    当我们希望在某个时间点来执行一些业务方法的时候就用到定时任务,在spring的项目中使用定时任务很简单.如下 第一步.加入jar包 <dependency> <groupId> ...

  5. spring项目中如何添加定时器以及在定时器中自动生成sprng注入对象

    最近做了一个java的项目,部门领导给了一套代码让我尽快掌握,说心里话本人真心不喜欢java的这种项目方式,各种配置各种xml文件简直头都大了,下面就将我遇到的其中一个我认为是坑的地方整理出来,希望能 ...

  6. 使用configuration配置结束在quartz.net中使用硬编码Job,Trigger任务提高灵活性

    经常在项目中遇到定时任务的时候,通常第一个想到的是Timer定时器,但是这玩意功能太弱鸡,实际上通常采用的是专业化的第三方调度框架,比如说 Quartz,它具有功能强大和应用的灵活性,我想使用过的人都 ...

  7. spring boot项目中处理Schedule定时任务

    项目中,因为使用了第三方支付(支付宝和微信支付),支付完毕后,第三方支付平台一般会采用异步回调通知的方式,通知商户支付结果,然后商户根据通知内容,变更商户项目支付订单的状态.一般来说,为了防止商户项目 ...

  8. java web 项目中 简单定时器实现 Timer

    java web 项目中 简单定时器实现 Timer 标签: Java定时器 2016-01-14 17:28 7070人阅读 评论(0) 收藏 举报  分类: JAVA(24)  版权声明:本文为博 ...

  9. maven Web项目中POM的配置信息

    什么是POM? POM是项目对象模型(Project Object Model)的简称,它是Maven项目中的文件,使用XML表示,名称叫做pom.xml.在Maven中,当谈到Project的时候, ...

随机推荐

  1. ZOJ 3949 (17th 浙大校赛 B题,树型DP)

    题目链接  The 17th Zhejiang University Programming Contest Problem B 题意  给定一棵树,现在要加一条连接$1$(根结点)和$x$的边,求加 ...

  2. 干净卸载mysql

    一.在控制面板中卸载mysql软件 二.卸载过后删除C:\Program Files (x86)\MySQL该目录下剩余了所有文件,把mysql文件夹也删了 三.windows+R运行“regedit ...

  3. HDU 5916: Harmonic Value Description

    题目描述 The harmonic value of the permutation $p_1,p_2,\cdots p_n$ is$$\sum_{i=1}^{n-1} gcd(p_i.p_{i+1} ...

  4. ORA-17129=SQL 字符串不是DML 语句

    ORA-17129=SQL 字符串不是DML 语句 oracle这个错误的意思是 select 不可以算DML 数据操纵语言(Data Manipulation Language, DML)是SQL语 ...

  5. SOAP、SOCKET协议

    一.SOAP( SOAP:Simple Object Access Protocol) 简单对象访问协议,简单对象访问协议(SOAP)是一种轻量的.简单的.基于 XML 的协议,它被设计成在 WEB ...

  6. Struts2笔记--文件上传

    Servlet 3.0规范的HttpServletRequest已经提供了方法来处理文件上传但这种上传需要在Servlet中完成.而Struts2则提供了更简单的封装. Struts2默认使用的是Ja ...

  7. 1,java的跨平台原理

    简单讲一下java的跨平台原理: (1)为什么跨平台: 由于各OS支持的指令集各不相同,就需要程序在不同的平台执行不同的代码 (2)JAVA是如何实现的: ava开发了适合不同的OS及不同位数的jav ...

  8. 理解 VMWare的3种网络模型 z

    在说到VMware的网络模型之前,先说一下VMware的几个虚拟设备: ■ VMnet0:这是VMware用于虚拟桥接网络下的虚拟交换机: ■ VMnet1:这是VMware用于虚拟Host-Only ...

  9. http://bbs.51cto.com/thread-1070029-1-1.html

    http://bbs.51cto.com/thread-1070029-1-1.html

  10. hive删除表报错

    metastore.RetryingHMSHandler: HMSHandler Fatal error: javax.jdo.JDODataStoreException: You have an e ...