Quartz使用及注意事项

前提:目前由于公司业务决定,大量使用Quartz,每天固定的时间点执行相应的业务逻辑,,几十个时间点应该是有的,某一个时间点如果没有执行带来的问题是巨大的。Quartz的稳定性、简单性大大的降低的开发维护成本。

放一个简单的Demo:https://github.com/Aresyl/LY.Quartz.git

1:Quartz 简介
Quartz是一个开源的作业调度框架,Quartz根据用户设定的时间规则来执行作业。Quartz主要分为:

a:scheduler就是任务调度器。

b:trigger就是触发器,用于定义任务调度时间规则 ,支持Cron表达式。文章最后给出几种常见的Cron表达式。

c:job就是作业即任务,即被调度的任务。在Job里Execute(IJobExecutionContext context)方法里面写业务即可,参数context 带有Job 的一些相关信息。

2:作业加载方式:

Quartz支持村代码添加作业,数据库加载,配置文件等等。这里讲下配置文件方式。配置文件主要包含:quartz.config、quartz_jobs.xml。

1:quartz.config:quartz 基础配置,包括:threadPool、plugin、exporter等一些信息。

2:quartz_jobs.xml:作业配置。每个schedule为一个计划,schedule节点下trigger为触发条件,可以为Job配置多个schedule,一个schedule也可以有多个trigger。

 特注:

1:时间调度配置文件出错(不符合XML)会导致所有Job 无法执行:

2:同一台服务器有多个Quartz 服务,记得更改 quartz.config配置下的quartz.scheduler.exporter.port配置,否则第二个服务作业一个也不会执行。

3:每个Job下引用的dll 记得和主任务版本相同,否则无法执行。

4:代码里写了Job,quartz_jobs.xml没有配置该Job,不会影响其他Job运行;如果quartz_jobs.xml配置了某个Job 但是代码里面没有,会导致所有Job无法运行。

 升级操作:

这样会遇到一个问题,每次更改某一个Job 发版会重启服务,势必会影响到其他Job的正常运行,Job越多越明显。这里提供一种方式:作业计划采用动态加载的方式,实际执行方法采用反射加载到内存,每次执行都是重新获取执行方法加载到内存。使触发和实际执行动作分离达到互不干扰的目的。

课后小作业:

我想9:30~22:00 每10分钟执行一次 trigger 应该怎么写?

1)Cron表达式的格式:秒 分 时 日 月 周 年(可选)

字段名            允许的值             允许的特殊字符

秒                0-59                 , - * /

分                0-59                 , - * /

小时              0-23                 , - * /

日                1-31                 , - * ? / L W C

月                1-12 or JAN-DEC      , - * /

周几              1-7 or SUN-SAT       , - * ? / L C #

年(可选字段)      empty,1970-2099      , - * /

2)特殊字符描述:

"?"字符:表示不确定的值

","字符:指定数个值

"-"字符:指定一个值的范围

"/"字符:指定一个值的增加幅度。n/m表示从n开始,每次增加m

"L"字符:用在日表示一个月中的最后一天,用在周表示该月最后一个星期X

"W"字符:指定离给定日期最近的工作日(周一到周五)

"#"字符:表示该月第几个周X。6#3表示该月第3个周五

3)Cron表达式范例:

每隔5秒执行一次:*/5 * * * * ?

每隔1分钟执行一次:0 */1 * * * ?

每天23点执行一次:0 0 23 * * ?

每天凌晨1点执行一次:0 0 1 * * ?

每月1号凌晨1点执行一次:0 0 1 1 * ?

每月最后一天23点执行一次:0 0 23 L * ?

每周星期天凌晨1点执行一次:0 0 1 ? * L

在26分、29分、33分执行一次:0 26,29,33 * * * ?

每天的0点、13点、18点、21点都执行一次:0 0 0,13,18,21 * * ?-->

Quartz使用及注意事项的更多相关文章

  1. quartz实例以及主要事项(注解)

    实现任务类: package com.vnetoo.nec.base.quartz; import org.springframework.context.annotation.Lazy;import ...

  2. Spring对Quartz的封装实现简单需注意事项

    前段时间在项目中一直使用正常的Quartz突然出现了任务漏跑的情况,由于我以前看过Quartz的内部实现,凭借记忆我觉得是由于Quartz的线程池的使用出现问题导致了故障的发生.为了搞清问题的真相,我 ...

  3. 【Quartz】问题记录注意事项【四】

    记录一:queartz 在同时启动多个任务是,触发器名称不能设置一致,不然第二次启动会不成功 记录二:quartz 在使用任务与触发器分离写法时,任务必须要带(.StoreDurably()) IJo ...

  4. 使用Spring整合Quartz轻松完成定时任务

    一.背景 上次我们介绍了如何使用Spring Task进行完成定时任务的编写,这次我们使用Spring整合Quartz的方式来再一次实现定时任务的开发,以下奉上开发步骤及注意事项等. 二.开发环境及必 ...

  5. Quartz集群原理及配置应用

    1.Quartz任务调度的基本实现原理 Quartz是OpenSymphony开源组织在任务调度领域的一个开源项目,完全基于Java实现.作为一个优秀的开源调度框架,Quartz具有以下特点: (1) ...

  6. Spring整合Quartz

    目录[-] 一.Spring创建JobDetail的两种方式 二.整合方式一示例步骤 1.将spring核心jar包.quartz.jar和Spring-context-support.jar导入类路 ...

  7. iOS基础 - Quartz 2D绘图

    一.Quartz 2D Quartz 2D是一个二维图形绘制引擎,支持iOS环境和Mac OS X环境. Quartz 2D以PDF的规范为基础的图形库,用来绘制二维文字和图形,允许相同的绘图指令在任 ...

  8. Spring4整合quartz2.2.3,quartz动态任务

    Spring4整合quartz2.2.3,quartz动态任务 >>>>>>>>>>>>>>>>> ...

  9. 【框架学习与探究之定时器--Quartz.Net 】

    声明 本文欢迎转载,原文地址:http://www.cnblogs.com/DjlNet/p/7572174.html 前言 这里相信大部分玩家之前现在都应该有过使用定时器的时候或者需求,例如什么定时 ...

随机推荐

  1. kali linux之xss

    攻击web客户端 客户端脚本语言(弹窗,广告,在浏览器中执行,javascript) javascript--与java语言无关,使用最广的客户端脚本语言 xss(cross-site scripti ...

  2. SignalR-001

    SignalR 是什么? ASP.NET Core SignalR 是一个开放源代码库,它简化了向应用添加实时 web 功能. 实时 web 功能立即使服务器端代码能够将内容推送到客户端. 一.有这么 ...

  3. Python3 + django2.0 + apache2 + ubuntu14部署网站上线

    自己尝试在本地搭建了 Django 项目后,想部署到自己云服务器上,经常多次尝试和多次踩坑(捂脸),总结如下: 环境:ubuntu14, django2.0, apache2. 1.首先安装需要的库包 ...

  4. 期待suqingnian.h

    不定期更新,跟着自己的进度走的. 有什么好的东西可以收录的尽管留言 UPD:话说真的没人发现本宝宝的$Martix$类的$operator$打错了么?$qwq$ $2018.7.19$ /*by Qi ...

  5. ORA-03113 : end-of-file on communication channel

    现象一: 数据库startup时,出现数据库无法正常mount,并报ORA-03113错误. SQL> startup ORACLE instance started. Total System ...

  6. AngularJS 1.x系列:AngularJS服务-Service

    1. AngularJS服务 AngularJS可注入类型包括:Service.Factory.Provider.Value及Constant. 2. Service AngularJS Servic ...

  7. 网址访问量统计插件 FlagCounter

    网址或博客访问量统计插件  ---> FlagCounter. 网址:http://s01.flagcounter.com/more/ERP2/

  8. Maven学习笔记(二)—— 整合SSH框架

    一.知识点准备 1.1 什么是依赖传递? 我们只添加一个struts2-core的依赖,结果会发现所有关于struts2的依赖都进来了. 因为我们的项目依赖struts2-core-2.3.24.ja ...

  9. pika教程

    http://www.01happy.com/python-pika-rabbitmq-summary/

  10. C++_IO与文件5-文件的输入与输出

    大多数计算机程序都使用了文件.文件本身是存储在某种设备上的一系列字节. 通常,操作系统管理文件,跟踪它们的位置.大小.创建时间等. 除非在操作系统级别上编程,否则通常不必担心这些事情. 真正需要的是将 ...