• Quartz任务调度框架相关方法、参数理解


    Quartz API中的关键接口

    • Job : Quartz提供的需实现的需调度器执行的任务组件接口,只有唯一接口:  void execute(JobExecutionContext var1) throws JobExecutionException;
    • job.class :实现了execute接口的作业类
    • JobDetail : 定义作业的实例,实现的任务组件类在此被作为参数传入实例
    • Trigger :触发器,定义作业执行计划的组件
    • JobBuilder : 用来构建JobDetail实例
    • TriggerBuilder : 用来构建Trigger实例
    • Scheduler :与调度程序交互的主要API,组合JobDetail和Trigger,启动任务调度,Scheduler在执行start后,触发Trigger,执行JobDetail

    下面来说说各个接口之间的关系

    1、Job和Trigger

    Trigger被触发时,excuate()被调度程序的一个工作线程调用,传递给excuate方法的参数JobExecutionContext中包含该Job实例中的所有运行参数(SchedulerJobDetailTrigger),保存在JobDataMap中。

    Quartz提供了多种不同类型的Trigger,最常用的两种:SimpleTriggerCronTrigger

    前者主要执行一些简单的定时调度,后者更突出的是在基于日历调度上的优势,比如每年的第2周的星期34:00执行。

    多数的任务调度框架将作业任务与调度任务都放在一起。Quartz将任务调度(Trigger)和作业任务(JobDetail)分开的理由如下:

    *作业任务与调度分开,当一个任务调度执行完毕后,可重新组装Trigger与JobDetail重新启用原来的作业任务,不用重新定义,的卢换马铠变赤兔,同样,同一个Trigger也可以重复和多个JobDetail组合使用,减少了耦合,提高了重用性。

    将Job和Trigger注册到Scheduler 时可为他们设置key(JobKeyTriggerKey)配置其身份属性,进而可以将他们放在不通分组(group)中,可基于分组操作。不同分组中的key值必须唯一,也可以理解为key值由name和group组成,必须唯一

    Job的并发

    @DisallowConcurrentExecution

    @PersistJobDataAfterExecution

     未完待续。。。

  • 相关阅读:
    C语言学习之指针
    IT人和普洱茶
    茶如人生 你是什么茶?
    普洱茶的冲泡技巧
    普洱茶保健功效
    廖雪峰Python总结3
    廖雪峰Python总结2
    Linux之软件包安装管理
    Linux常用命令6 关机重启命令
    Linux之Vim编辑器
  • 原文地址:https://www.cnblogs.com/lansetuerqi/p/14039487.html
Copyright © 2020-2023  润新知