Listener

调度任务的监听,当前版本支持添加调度,触发器和任务的监听,其中触发器和任务的监听支持通过监听名称进行添加(Add*ListenerMatcher方法)

监听不能对外抛出异常,需要内部处理,类似于切面,监听的返回结果不会影响程序主体

Job Listener
  • IJobListener 接口
public interface IJobListener
{
string Name { get; }
// 执行前
Task JobToBeExecuted(IJobExecutionContext context);
// 作业即将被执行,但是被触发器否决了
Task JobExecutionVetoed(IJobExecutionContext context);
// 执行完毕
Task JobWasExecuted(IJobExecutionContext context, JobExecutionException jobException);
}
  • Quartz.NET 自带一个监听的虚函数:JobListenerSupport

  • 向ListenerManager中添加监听

    //监听指定的任务
    scheduler.ListenerManager.AddJobListener(myJobListener, KeyMatcher<JobKey>.KeyEquals(new JobKey("myJobName", "myJobGroup")));
    // 监听指定的群组
    scheduler.ListenerManager.AddJobListener(myJobListener, GroupMatcher<JobKey>.GroupEquals("myJobGroup"));
    // 监听多个群组
    scheduler.ListenerManager.AddJobListener(myJobListener,
    OrMatcher<JobKey>.Or(GroupMatcher<JobKey>.GroupEquals("myJobGroup"), GroupMatcher<JobKey>.GroupEquals("yourGroup")));
    // 所有任务都监听
    scheduler.ListenerManager.AddJobListener(myJobListener, GroupMatcher<JobKey>.AnyGroup());
Tigger Listener
  • ITriggerListener 接口
public interface ITriggerListener
{
string Name { get; }
// 触发器激活时触发
Task TriggerFired(ITrigger trigger, IJobExecutionContext context);
// 触发器失效后出发
Task<bool> VetoJobExecution(ITrigger trigger, IJobExecutionContext context);
// 执行失效后触发(执行未执行指令时出现问题-超时或者异常)
Task TriggerMisfired(ITrigger trigger);
// 触发器失效后触发
Task TriggerComplete(ITrigger trigger, IJobExecutionContext context, int triggerInstructionCode);
}
  • Quartz.NET 自带一个监听的虚函数:TriggerListenerSupport
  • 向ListenerManager中添加监听方式与Job一致,只是第一个参数改为了ITriggerListener的实现类
Scheduler Listener
  • ISchedulerListener接口

    public interface ISchedulerListener
    {
    // 当IJobDetail添加到IScheduler时触发
    Task JobScheduled(Trigger trigger);
    // 当卸载IJobDetail时触发(如果任务设置为非持久化,则触发器结束任务会被卸载)
    Task JobUnscheduled(string triggerName, string triggerGroup);
    // 触发器完成时触发
    Task TriggerFinalized(Trigger trigger);
    // 触发器暂停时触发
    Task TriggersPaused(string triggerName, string triggerGroup);
    // 重新开始时触发
    Task TriggersResumed(string triggerName, string triggerGroup);
    // 任务暂停时触发
    Task JobsPaused(string jobName, string jobGroup);
    // 任务重新开始触发
    Task JobsResumed(string jobName, string jobGroup);
    // 调度器出现问题时触发
    Task SchedulerError(string msg, SchedulerException cause);
    // 调度器关闭时触发
    Task SchedulerShutdown();
    }
  • 向ListenerManager中添加/移除监听

    // 添加
    scheduler.ListenerManager.AddSchedulerListener(mySchedListener);
    // 移除
    scheduler.ListenerManager.RemoveSchedulerListener(mySchedListener);

JobStore

该类存储了调度器中的工作数据(所有的任务,触发器和日历),可以通过对JobStore进行配置来实现对调度器中数据的管理(例如存储到数据库中等)

警告:不要再代码中使用JobStore实例,JobStore由Quartz.NET自主执行,可以通过配置进行设置。

  • JobStore设置

    1.配置文件(quartz.properties)中配置

    // 默认使用RAMJobStore配置
    quartz.jobStore.type = Quartz.Simpl.RAMJobStore, Quartz

    2.代码中进行配置

    // 创建JobStore
    JobStore jobStore = new RAMJobStore();
    // 创建线程池(Quartz.NET自带的CLR的托管线程池)
    var threadPool = new DefaultThreadPool();
    // 最大并发数,默认是10
    // threadPool.MaxConcurrency = 10;
    // 初始化
    threadPool.Initialize();
    // 创建Schedule
    IScheduler sched = DirectSchedulerFactory.Instance.CreateScheduler(new DefaultThreadPool(), jobStore);
  • JobStore各配置说明

    1. RAMJobStore

      Quartz.NET默认选项,将所有数据都保存到RAM中,因此效率最高;缺点是数据不是持久保存的,奔溃/结束后数据会被释放。

      使用RAMJobStore时可直接使用StdSchedulerFactory创建调度器,无需做其他操作

    2. AdoJobStore

      通过ADO.NET将数据存储在数据库中,性能下降程度需要看是否创建了主键索引。

      Sql脚本在database/tables下面,表名前缀为QRTZ_

      可以使用JobStoreTX来管理事务,数据源需要额外配置

      // 将类型设置为JobStoreTX
      quartz.jobStore.type = Quartz.Impl.AdoJobStore.JobStoreTX, Quartz
      //DriverDelegate驱动代理,设置需要那种数据库
      // StdAdoDelegate为ADO.NET的相关配置库
      quartz.jobStore.driverDelegateType = Quartz.Impl.AdoJobStore.StdAdoDelegate, Quartz
      // 表前缀设置
      quartz.jobStore.tablePrefix = QRTZ_
      // 数据源名称
      quartz.jobStore.dataSource = myDS
      // 数据源连接字符串
      quartz.dataSource.myDS.connectionString = Server=localhost;Database=quartz;Uid=quartznet;Pwd=quartznet
      // 数据库信息
      quartz.dataSource.myDS.provider = MySql
      // 将JobDataMaps的相关数据也进行保存
      quartz.jobStore.useProperties = true
      // 序列化的格式为json
      quartz.serializer.type = json

      Quarz.NET支持的数据库列表如下(与资源配置中的支持列表不同,建议已资源配置的为准):

      • SqlServer - SQL server的数据库链接

        • 除了3.1版本外,默认依赖包为System.Data.SqlClient
        • .NET Core(3.2版本)默认依赖包为 Microsoft.Data.SqlClient
      • SystemDataSqlClient - framework 的默认设置
      • MicrosoftDataSqlClient - .NET Core默认设置
      • OracleODP - Oracle 数据库链接
      • OracleODPManaged - Oracle 11及以上
      • MySql - MySQL
      • SQLite - SQLite
      • SQLite-Microsoft - Microsoft SQLite
      • Firebird - Firebird
      • Npgsql - PostgreSQL

Quartz.Net 官方教程 Tutorial 2/3(Listener 和 JobStore)的更多相关文章

  1. Quartz.net官方开发指南系列篇

    Quartz.NET是一个开源的作业调度框架,是OpenSymphony 的 Quartz API的.NET移植,它用C#写成,可用于winform和asp.net应用中.它提供了巨大的灵活性而不牺牲 ...

  2. Unity性能优化(3)-官方教程Optimizing garbage collection in Unity games翻译

    本文是Unity官方教程,性能优化系列的第三篇<Optimizing garbage collection in Unity games>的翻译. 相关文章: Unity性能优化(1)-官 ...

  3. Unity性能优化(4)-官方教程Optimizing graphics rendering in Unity games翻译

    本文是Unity官方教程,性能优化系列的第四篇<Optimizing graphics rendering in Unity games>的翻译. 相关文章: Unity性能优化(1)-官 ...

  4. Unity性能优化(2)-官方教程Diagnosing performance problems using the Profiler window翻译

    本文是Unity官方教程,性能优化系列的第二篇<Diagnosing performance problems using the Profiler window>的简单翻译. 相关文章: ...

  5. Quartz2.2.x官方教程

    零.Quartz是什么?能干什么? Quartz是一个开源的任务调度框架.基于定时.定期的策略来执行任务是它的核心功能,比如x年x月的每个星期五上午8点到9点,每隔10分钟执行1次.Quartz有3个 ...

  6. [爬虫] 学Scrapy,顺便把它的官方教程给爬下来

    想学爬虫主要是因为算法和数据是密切相关的,有数据之后可以玩更多有意思的事情,数据量大可以挖掘挖掘到更多的信息. 之前只会通过python中的request库来下载网页内容,再用BeautifulSou ...

  7. Note | PyTorch官方教程学习笔记

    目录 1. 快速入门PYTORCH 1.1. 什么是PyTorch 1.1.1. 基础概念 1.1.2. 与NumPy之间的桥梁 1.2. Autograd: Automatic Differenti ...

  8. Unity性能优化(1)-官方教程The Profiler window翻译

    本文是Unity官方教程,性能优化系列的第一篇<The Profiler window>的简单翻译. 相关文章: Unity性能优化(1)-官方教程The Profiler window翻 ...

  9. jeecg表单页面控件权限设置(请先看官方教程,如果能看懂就不用看这里了)

    只是把看了官方教程后,觉得不清楚地方补充说明一下: 1. 2. 3. 4.用"jeecgDemoController.do?addorupdate"这个路径测试,不出意外现在应该可 ...

  10. [转]Google Guava官方教程(中文版)

    Google Guava官方教程(中文版) http://ifeve.com/google-guava/

随机推荐

  1. [VUE]报错: No Babel config file detected for

    在使用vue脚手架创建的项目中,项目中每个文件的第一行都会有红色波浪线. 解决方法:在项目文件中找到package.json文件,在parserOptions里添加"requireConfi ...

  2. (线段树) P4588 数学计算

    小豆现在有一个数 x,初始值为 1.小豆有 QQ 次操作,操作有两种类型: 1 m:将 x变为 x × m,并输出 x mod M 2 pos:将 x 变为 x 除以第 pos次操作所乘的数(保证第  ...

  3. uniapp之uni-starter小程序多端研发框架搭建与项目实践

    随着移动互联网的飞速发展,无数移动APP琳琅满目:在移动App的发展的基础上,衍生了小程序.轻应用技术,它随时可用,但又无需安装卸载.小程序是一种不需要下载安装即可使用的应用,它实现了应用" ...

  4. SpringBoot启动流程源码分析

    前言 SpringBoot项目的启动流程是很多面试官面试中高级Java程序员喜欢问的问题.这个问题的答案涉及到了SpringBoot工程中的源码,也许我们之前看过别的大牛写过的有关SpringBoot ...

  5. 第一章 计算机和C++简介

    1.1 简介 C++是一种强大的计算机面向对象编程的程序设计语言,它是制造软件的一种编程语言,适合程序员和刚接触编程的技术人员.当今智能手机销量爆炸式增长给移动应用程序的开发带来了很多机会,而C++就 ...

  6. <一>关于运算符重载

    C++的运算符重载:使对象的运算表现得和编译器内置类型一样 如下代码,如果T是整形,那很好理解,但是如果 T 是一个 Student 类, a + b ?怎么操作,两个学生类怎么相加? 这个就是我们要 ...

  7. VulnHub靶场渗透实战8-DarkHole: 2

    靶场地址:DarkHole: 2 ~ VulnHub DescriptionBack to the Top Difficulty:Hard This works better with VMware ...

  8. 2.9:数据交换-csv、Excel、json、爬虫、Tushare获取数据

    〇.任务 1. 使用Python基础文件读写函数完成CSV文件的处理: 2. 使用标准CSV库完成CSV文件的处理: 3. 使用Excel库完成Excel文件的处理: 4. Python数据结构和Js ...

  9. 【离线数仓】Day01-用户行为数据采集:数仓概念、需求及架构、数据生成及采集、linux命令及其他组件常见知识

    一.数据仓库概念 二.项目需求及架构设计 1.需求分析 2.项目框架 3.框架版本选型 服务器选型:云主机 服务器规划 三.数据生成模块 1.数据基本格式 公共字段:所有手机都包含 业务字段:埋点上报 ...

  10. .NET 6 中外部引用项目NU1105异常问题解决

    .NET 6 Project中,添加了其他解决方案的工程后,本地能编译通过,代码签入后,其他同事下载代码,编译报错: 错误 NU1105 找不到"E:\Teld\01Code\TTP_CTP ...