quartz项目中的运用

下面是之前项目中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到日志表中

时间: 2024-11-02 02:47:57

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

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

项目中使用Quartz集群分享--转载 在公司分享了Quartz,发布出来,希望大家讨论补充. CRM使用Quartz集群分享  一:CRM对定时任务的依赖与问题  二:什么是quartz,如何使用,集群,优化  三:CRM中quartz与Spring结合使用 1:CRM对定时任务的依赖与问题  1)依赖  (1)每天晚上的定时任务,通过sql脚本 + crontab方式执行 Xml代码   #crm 0 2 * * * /opt/***/javafiles/***/shell/***_dail

java项目中可能会使用到的jar包解释

一.Struts2 用的版本是struts2.3.1.1 一个简单的Struts项目所需的jar包有如下8个 1. struts2-core-2.3.1.1.jar: Struts2的核心类库. 2. xwork-core-2.3.1.1.jar: XWork核心类,XWork是一个标准的command模式实现,并且完全从web层剥离出来.WebWork被构建在Xwork上,而Struts2由Struts1和WebWork两个经典的MVC框架发展而来. 3. ognl-3.0.3.jar: 支持

在Spring项目中使用@Scheduled注解定义简单定时任务

如题所示,有时候我们需要在Web项目中配置简单的定时任务,而且因为任务并不复杂不想使用定时调度框架(PS:Quartz.ActiveMQ .Kafka等),这时就可以考虑使用@Scheduled注解来定义简单的定时任务.其全部配置如下: (1)在Spring的配置文件中添加定时任务相关配置: xml配置的头文件中添加: xmlns:task="http://www.springframework.org/schema/task" 以及在xsi:schemaLocation中添加: ht

Quartz使用(6) - Quartz项目实战

本片博文将阐述项目工作中使用Quartz的情况,包含项目背景.项目框架.Quartz集群部署等方面,重点讲述如何在实际项目中使用Quartz. 1. 背景 因项目需求,需要定时调用数据下载接口,并将数据存储至诸如mongo.redis.elasticsearch等数据库或缓存中.具体涉及到的需求如下: a. 调用接口的任务均从mongo数据库读取; b. 任务的个数随着业务量的增加而增加; c. 每个调用任务的定时执行时间可能不同,且定时执行时间在mongo中可配置; d. 任务的执行需要动态更

在asp.net core的项目中通过log4net添加日志记录到本地文件

=============================================== 2020/2/25_第1次修改                       ccb_warlock =============================================== 由于之前的时间都忙于项目的业务开发,对于log4net的使用一直是“拿来主义”,仅仅用在了调试时输出到控制台看结果,而没有深究配置文件的参数和具体的机制. 正巧这段时间项目进度没有那么紧张,我也有时间来完善框

用java写一个远程视频监控系统,实时监控(类似直播)我想用RPT协议,不知道怎么把RPT协议集成到项目中

我最近在用java写一个远程视频监控系统,实时监控(类似直播)我想用RPT协议,不知道怎么把RPT协议集成到项目中,第一次写项目,写过这类项目的多多提意见,哪方面的意见都行,有代码或者demo的求赏给我,谢谢

DotNet项目中的一些常用验证操作

在项目中需要对用户输入的信息,以及一些方法生成的结果进行验证,一般在项目中较多的采用js插件或js来进行有关信息的校验,但是从项目安全性的角度进行考虑,可对系统进行js注入. 如果在后台对用户输入的信息进行验证会相对的安全,在出现信息验证不合法时,可以直接在程序中抛出异常,终止程序的运行. 现在提供几种较为常用的验证方法,可以减少在项目中开发时间和错误性: 1.判断域名:         /// <summary>         /// 普通的域名         /// </summ

javaWeb项目中如何实现在线查看pdf文件

最近有需求要实现在网页直接查看pdf,word,excel文件.但是实际当中并没有很好的开源插件供我们使用,确实有一些付费的插件不错,也很好用,但是对于我来说都不适合. 现在只是单纯的找到了围魏救赵的方法. 就是先实现显示pdf文件,其他文件用别的方式去转成pdf.虽然这个方法确实不好,但是也是没有办法的办法了,如果以后能有更好的,那就再发布别的吧. 这里我就直接介绍pdf的显示方法. 直接上干货. 首先在E:\tomcat8\webapps这个目录下面拷贝下面这个文件 http://yunpa

Python+Selenium进行UI自动化测试项目中,常用的小技巧2:读取配置文件(configparser,.ini文件)

在自动化测试项目中,可能会碰到一些经常使用的但 很少变化的配置信息,下面就来介绍使用configparser来读取配置信息config.ini 读取的信息(config.ini)如下: [config]platformName=AndroidappPackage=com.sheinsideappActivity=.module.GuideActivitybaseUrl=http://0.0.0.0:4723/wd/hubfindElementTimes=10[cmd]openAppium=nod