【各种任务调度的使用场景】

  论坛每天凌晨统计论坛用户的积分排名。

  论坛每半个小时生成精华文章。

  每隔30分钟对锁定过期的用户解锁。

  每月1号统计上个月各部门的业务数据。

【Quartz 简介】

  Quartz提供了强大的任务调度机制,Quartz允许开发人员灵活地定义触发器的调度时间表,并可以对触发器和任务进行关联映射。

  Quartz还提供了调度运行环境的持久化机制,可以保存并恢复调度现场,即使系统因故障关闭,任务调度现场数据并不会丢失。

  Quartz还提供了组件式的侦听器、各种插件、线程池等功能。

【Quartz 基础结构】

[ Job ]

  Job是一个接口,只有一个方法 void execute( JobExecutionContext context ),开发者实现该接口并在方法里定义需要执行的任务。

  JobExecutionContext 类提供了调度上下文的各种信息。

  Job运行时的信息保存在JobDataMap中。

[ JobDetail ]

  Quartz在每次执行Job时,都重新创建一个Job实例。

  JobDetail描述了Job的实现类以及其他相关的静态信息,如Job名称、描述、关联监听器等信息。

  构造方法:JobDetial(String name,String group, Class jobClass)。jobClass就是对应的Job的实现类。

[ Trigger ]

  是一个类,描述触发Job执行的时间触发规则。

  主要有SimpleTrigger 和 cronTrigger这两个子类。

  SimpleTrigger:适合 当仅需要一次或者以固定时间间隔周期执行的任务。

  CronTrigger:使用Cron表达式定义出各种复杂的调度方案,如每天早上8点、每周一下午5点。

[ Calendar ]

  是org.quartz.Calendar。

  它是一些日历特定时间点的集合。

  一个Trigger可以和多个Calendar关联,以便排除或者包含某些时间点。

[ Schedular ]

  代表一个Quartz的独立运行的容器。

  Trigger和JobDetail可以注册到Scheduler中,两者在Scheduler中拥有自己组合名称。

  组以及名称是Scheduler查找某一对象的依据,Trigger、JobDetail的组名、名称必须唯一。

  Scheduler可以将Trigger绑定到某一个JobDetail中,这样当Trigger被触发时,对应的Job就被执行。

  一个Job可以对应多个Trigger,一个Trigger只能对应一个Job。

  Scheduler实例可以由SchedulerFactory工厂创建。

  Scheduler中拥有一个SchedulerContext,保存着Scheduler的上下文信息,Job和Trigger都可以访问SchedulerContext中的信息。SchedulerContext内部通过一个Map维护这些上下文数据。

[ ThreadPool ]

  Scheduler使用一个线程池作为任务运行的基础设施。任务通过共享线程池中的线程提高运行效率。

【Quzrtz内部组件结构图】

一个Scheduler可以拥有多个Trigger和JobDetail,他们可以分到不同的组中。

Scheduler注册Trigger和JobDetail时,如果不显式指定所属的组,Scheduler将会将其放入默认组中,默认组的组名为Scheduler.DEFAULT_GROUP。组名和名称组成了对象的全名,统一类型对象的全名不能相同。

01_Quartz基础结构的更多相关文章

  1. Apworks框架实战(六):使用基于Entity Framework的仓储基础结构

    在前面的章节中,我们已经设计了一个简单的领域模型,接下来我们希望能够实现领域模型的持久化及查询.在Apworks中,实现了面向Entity Framework.NHibernate以及MongoDB的 ...

  2. 开放式管理基础结构 OMI

    Windows 长久以来在 CIM 实施领域一直傲立桥头,而这一切都是从 WMI(Windows 管理基础结构)开始的.分布式管理任务组 (DMTF) 通用信息模型 (CIM) 是一种开放式标准,用于 ...

  3. 设置将 Microsoft Azure 的网络基础结构以支持设置为灾难恢复站点

    Prateek Sharma 云 + Enterprise 高级项目经理 Azure SiteRecovery (ASR)可以将Microsoft Azure用作您的虚拟机的灾难恢复站点. 当管理 ...

  4. 转载文章:Windows Azure 基础结构服务上的 Microsoft Dynamics NAV 和 Microsoft Dynamics GP!

    Windows Azure 基础结构服务(虚拟机和虚拟网络)可提供按需基础结构,该基础结构可进行伸缩以适应不断变化的业务需求.无论您是在虚拟机中创建新应用程序,还是运行现有应用程序,我们都将按分钟收费 ...

  5. Gartner 认定 Microsoft 为具有远见卓识的云基础结构即服务提供商

    四个月前, Windows Azure 基础结构服务结束了预览版阶段,正式发布了,它具有业内领先的 SLA.随后, 凭借愿景的完整性和执行力,Gartner 很快认可了 Microsoft 在市场中的 ...

  6. 1详细解析HTML基础结构

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  7. 详细解析HTML基础结构

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  8. 适用于 Windows VM 的 Azure 示例基础结构演练

    本文是更广泛系列的一部分,当你在 Azure 中构建应用程序基础结构时,这些系列向你提供设计注意事项和准则. 用户可以查看系列中的其他主题. 尽管用户可以在 Azure 中快速地构建出开发/测试环境, ...

  9. 在 Azure 中将基础结构自动化工具与虚拟机配合使用

    若要以一致的方式大规模创建和管理 Azure 虚拟机 (VM),通常需要某种形式的自动化. 可以通过许多工具和解决方案来自动完成整个 Azure 基础结构部署和管理生命周期. 本文介绍了一些可以在 A ...

随机推荐

  1. 百度地图中使用mouseover事件获取经纬度时无法拿到鼠标所在位置的经纬度。

    用百度2.0的话使用mousemove 鼠标在地图区域移动过程中触发此事件.mouseover参数e中没有point参数

  2. Flask之flask_script

    flask端口占用 解决方案: lsof -i:5000 #查询是哪个进程占用的 kill PID 杀掉进程 flask_script之Manager类 from flask import Flask ...

  3. Scrum3.0 敏捷开发白皮书

    一.什么是敏捷? 敏捷是一种以用户需求为核心.采用不断迭代的方式进行的软件开发模式.敏捷依靠自组织 的跨职能小团队,在短周期内,做出小块的东西来,通过快速.频繁的迭代,迅速的获取反 馈,进而不断的完善 ...

  4. TT 安装之 Windwos

    WINDOWS在 控制面板-〉管理工具-〉本地安全策略-〉本地策略-〉用户权限分配-〉锁定内存页-〉添加用户或组-〉高级查找 然后确定 然后安装 (WINDOWS在 控制面板-〉管理工具-〉ODBC工 ...

  5. linux 重新定义命令alias——重定义查看日志命令

    背景:很多时候,需要输入一大串命令来查看日志,例如: cd /home/weblogic/prodmain/log/ftlog;tail -f tps-mv-ft-rolling.log 每次打开终端 ...

  6. ssh设置超时时间

    修改server端的etc/ssh/sshd_config ClientAliveInterval 60 #server每隔60秒发送一次请求给client,然后client响应,从而保持连接 Cli ...

  7. PIXI 精灵及文本加载(4)

    预习下官网的知识. 及字母消除接上文 Pixi 精灵 Pixi拥有一个精灵类来创建游戏精灵.有三种主要的方法来创建它: 用一个单图像文件创建. 用一个 雪碧图 来创建.雪碧图是一个放入了你游戏所需的所 ...

  8. FileSearch.java

    !=fileList.size()) { ]) { fileOutputStream.write(bytes; i < files.length; i++) {// 将其中的文件夹遍历出来,并调 ...

  9. ubuntu18.04 与 python

    Ubuntu安装pycharm专业破解版方法 首先我们要下载pycharm的安装包, 地址为https://www.jetbrains.com/pycharm/download/#section=li ...

  10. Python+Selenium定位元素的方法

    Python+Selenium有以下八种定位元素的方法: 1. find_element_by_id() eg: find_element_by_id("kw") 2. find_ ...