我们都知道默认的Quartz底层采用的是RAMJobStore,所有的Job,Trigger,Calendar都是用Dictionary,SortSet等等这样的数据结构进行储存,相对来说性

能肯定快的没法说,但是面对灾难重启的时候还是很拿不出手的,而且都是全内存的,也没法实现多机器搭建Quartz集群,这一点还是很讨厌,虽然官方已经

提供了一些关系性持久化存储方案,但面对如今这么火的nosql,不进行官方支持还是有点可惜,不过基于Quartz本身的插拔式设计,一切都不是问题。

一:IJobStore

   从github上下载源码:https://github.com/quartznet/quartznet,从源码你会发现IJobStore几乎实现了所有对Trigger,Job和Scheduler所有的容器管理操作。

然后你可以看到它的几个实现子类,全内存的RAMJobStore。

  1. public class RAMJobStore: IJobStore
  2. {
  3. ....
  4. }

以及JobStoreSupport下的带锁JobStoreTX和不带锁的JobStoreCMT。

  1. public class JobStoreSupport: IJobStore
  2. {
  3. ....
  4. }
  5.  
  6. //带锁机制
  7. public class JobStoreTX: JobStoreSupport
  8. {
  9. ....
  10. }
  11.  
  12. //不带锁
  13. public class JobStoreCMT: JobStoreSupport
  14. {
  15. ....
  16. }

所以你应该明白,本节课跟大家讲到的Redis和Mongodb的JobStore存储,必然也是实现了IJobStore接口,对吧。

二:MongoDB的JobStore

1. 安装mongodb

既然要使用mongodb,你必然要有mongodb的安装程序,可以去官网: wget https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-3.4.5.tgz 一下,

这里我采用linux平台的centos。

2. nuget上pull些dll

大家可以在nuget控制台执行Install-Package Quartz.Spi.MongoDbJobStore,如下所示:

  1. PM> Install-Package Quartz.Spi.MongoDbJobStore
  2. 正在尝试收集与目标为“.NETFramework,Version=v4.5.2”的项目“ConsoleApplication1”有关的包“Quartz.Spi.MongoDbJobStore.2.0.”的依赖项信息
  3. 正在尝试解析程序包“Quartz.Spi.MongoDbJobStore.2.0.”的依赖项,DependencyBehavior 为“Lowest
  4. 正在解析操作以安装程序包“Quartz.Spi.MongoDbJobStore.2.0.”
  5. 已解析操作以安装程序包“Quartz.Spi.MongoDbJobStore.2.0.”
  6. 正在将程序包“Common.Logging.Core.3.3.”添加到文件夹“C:\\ConsoleApplication1\packages
  7. 已将程序包“Common.Logging.Core.3.3.”添加到文件夹“C:\\ConsoleApplication1\packages
  8. 已将程序包“Common.Logging.Core.3.3.”添加到“packages.config
  9. 已将“Common.Logging.Core 3.3.”成功安装到 ConsoleApplication1
  10. 正在将程序包“Common.Logging.3.3.”添加到文件夹“C:\\ConsoleApplication1\packages
  11. 已将程序包“Common.Logging.3.3.”添加到文件夹“C:\\ConsoleApplication1\packages
  12. 已将程序包“Common.Logging.3.3.”添加到“packages.config
  13. 已将“Common.Logging 3.3.”成功安装到 ConsoleApplication1
  14. 正在将程序包“MongoDB.Bson.2.4.”添加到文件夹“C:\\ConsoleApplication1\packages
  15. 已将程序包“MongoDB.Bson.2.4.”添加到文件夹“C:\\ConsoleApplication1\packages
  16. 已将程序包“MongoDB.Bson.2.4.”添加到“packages.config
  17. 已将“MongoDB.Bson 2.4.”成功安装到 ConsoleApplication1
  18. 正在将程序包“Quartz.2.4.”添加到文件夹“C:\\ConsoleApplication1\packages
  19. 已将程序包“Quartz.2.4.”添加到文件夹“C:\\ConsoleApplication1\packages
  20. 已将程序包“Quartz.2.4.”添加到“packages.config
  21. 已将“Quartz 2.4.”成功安装到 ConsoleApplication1
  22. 正在将程序包“System.Runtime.InteropServices.RuntimeInformation.4.3.”添加到文件夹“C:\\ConsoleApplication1\packages
  23. 已将程序包“System.Runtime.InteropServices.RuntimeInformation.4.3.”添加到文件夹“C:\\ConsoleApplication1\packages
  24. 已将程序包“System.Runtime.InteropServices.RuntimeInformation.4.3.”添加到“packages.config
  25. 已将“System.Runtime.InteropServices.RuntimeInformation 4.3.”成功安装到 ConsoleApplication1
  26. 正在将程序包“MongoDB.Driver.Core.2.4.”添加到文件夹“C:\\ConsoleApplication1\packages
  27. 已将程序包“MongoDB.Driver.Core.2.4.”添加到文件夹“C:\\ConsoleApplication1\packages
  28. 已将程序包“MongoDB.Driver.Core.2.4.”添加到“packages.config
  29. 已将“MongoDB.Driver.Core 2.4.”成功安装到 ConsoleApplication1
  30. 正在将程序包“MongoDB.Driver.2.4.”添加到文件夹“C:\\ConsoleApplication1\packages
  31. 已将程序包“MongoDB.Driver.2.4.”添加到文件夹“C:\\ConsoleApplication1\packages
  32. 已将程序包“MongoDB.Driver.2.4.”添加到“packages.config
  33. 已将“MongoDB.Driver 2.4.”成功安装到 ConsoleApplication1
  34. 正在将程序包“Quartz.Spi.MongoDbJobStore.2.0.”添加到文件夹“C:\\ConsoleApplication1\packages
  35. 已将程序包“Quartz.Spi.MongoDbJobStore.2.0.”添加到文件夹“C:\\ConsoleApplication1\packages
  36. 已将程序包“Quartz.Spi.MongoDbJobStore.2.0.”添加到“packages.config
  37. 已将“Quartz.Spi.MongoDbJobStore 2.0.”成功安装到 ConsoleApplication1

也可以到github中下载源码:https://github.com/chrisdrobison/mongodb-quartz-net

3. 启动运行

然后可以看一下此页面上的Basic Usage##上的默认配置:

  1. var properties = new NameValueCollection();
  2. properties[StdSchedulerFactory.PropertySchedulerInstanceName] = instanceName;
  3. properties[StdSchedulerFactory.PropertySchedulerInstanceId] = $"{Environment.MachineName}-{Guid.NewGuid()}";
  4. properties[StdSchedulerFactory.PropertyJobStoreType] = typeof (MongoDbJobStore).AssemblyQualifiedName;
  5. // I treat the database in the connection string as the one you want to connect to
  6. properties[$"{StdSchedulerFactory.PropertyJobStorePrefix}.{StdSchedulerFactory.PropertyDataSourceConnectionString}"] = "mongodb://localhost/quartz";
  7. // The prefix is optional
  8. properties[$"{StdSchedulerFactory.PropertyJobStorePrefix}.collectionPrefix"] = "prefix";
  9.  
  10. var scheduler = new StdSchedulerFactory(properties);
  11. return scheduler.GetScheduler();

<1>  PropertySchedulerInstanceName: 就是对Scheduler的Name进行的配置,大家可以根据情况定义一个简明释义的名字。

<2> PropertySchedulerInstanceId: 可以看到这个项采用的是machineName+NewGuid来保证Scheduler容器的SchedulerID唯一,唯一性特别重要,因为在

                 Cluster 中就是用它来保证唯一性的,不过上面的代码有点累赘,其实只要写上“AUTO”就可以了,由底层的

                           SimpleInstanceIdGenerator来保证uniqueID的生成,如StdSchedulerFactory.Instantiate方法源码所示:

  1. if (schedInstId.Equals(AutoGenerateInstanceId))
  2. {
  3. autoId = true;
  4. instanceIdGeneratorType = LoadType(cfg.GetStringProperty(PropertySchedulerInstanceIdGeneratorType)) ?? typeof(SimpleInstanceIdGenerator);
  5. }
  6. else if (schedInstId.Equals(SystemPropertyAsInstanceId))
  7. {
  8. autoId = true;
  9. instanceIdGeneratorType = typeof(SystemPropertyInstanceIdGenerator);
  10. }

<3> PropertyJobStoreType:这个属性将MongoDbJobStore作为底层的IJobStore实现者。

<4> PropertyDataSourceConnectionString,collectionPrefix: 这两个没什么好说的,一个是mongodb的connectionstring,一个是collection的前缀。

好了,下面就是我的完整代码:

  1. static void Main(string[] args)
  2. {
  3.  
  4. LogManager.Adapter = new Common.Logging.Simple.TraceLoggerFactoryAdapter()
  5. {
  6. Level = LogLevel.All
  7. };
  8.  
  9. var properties = new NameValueCollection();
  10. properties[StdSchedulerFactory.PropertySchedulerInstanceId] = "AUTO";
  11. properties[StdSchedulerFactory.PropertyJobStoreType] = typeof(MongoDbJobStore).AssemblyQualifiedName;
  12.  
  13. // I treat the database in the connection string as the one you want to connect to
  14. properties[$"{StdSchedulerFactory.PropertyJobStorePrefix}.{StdSchedulerFactory.PropertyDataSourceConnectionString}"] = "mongodb://192.168.23.163/quartz";
  15.  
  16. // The prefix is optional
  17. properties[$"{StdSchedulerFactory.PropertyJobStorePrefix}.collectionPrefix"] = "prefix";
  18.  
  19. var factory = new StdSchedulerFactory(properties);
  20.  
  21. //scheduler
  22. IScheduler scheduler = factory.GetScheduler();
  23.  
  24. scheduler.Start();
  25.  
  26. var job = JobBuilder.Create<HelloJob>().WithIdentity("test", "datamip").Build();
  27.  
  28. var trigger = TriggerBuilder.Create().WithCronSchedule("* * * * * ?").Build();
  29.  
  30. if (!scheduler.CheckExists(job.Key))
  31. {
  32. scheduler.ScheduleJob(job, trigger);
  33. }
  34.  
  35. Console.Read();
  36. }

这个我自定义的HelloJob中,我特意记录一下scheduler的调度时间schedulertime和Trigger应该触发的时间nextFireTime。

  1. class HelloJob : IJob
  2. {
  3. static int index = ;
  4.  
  5. public void Execute(IJobExecutionContext context)
  6. {
  7. Console.WriteLine("{4} index={0},current={1}, scheuler={2},nexttime={3}",
  8. index++, DateTime.Now,
  9. context.ScheduledFireTimeUtc?.LocalDateTime,
  10. context.NextFireTimeUtc?.LocalDateTime,
  11. context.JobDetail.JobDataMap["key"]);
  12. }
  13. }

接下来执行一下:

然后通过robomongo到数据库看一下,有5个collection,里面都有数据,没毛病。

好了,本篇就说到这里了,当然还有基于redis的JobStore,有兴趣大家可以自己尝试一下。

使用mongodb作为Quartz.Net下的JobStore实现底层的持久化机制的更多相关文章

  1. Quartz.net 3.x使用总结(二)——Db持久化和集群

    上一篇简单介绍了Quartz.net的概念和基本用法,这一篇记录一下Quartz.net通过数据库持久化Trigger和Jobs等数据,并简单配置Quartz.net的集群. 1.JobStore介绍 ...

  2. 痞子衡嵌入式:MCUXpresso IDE下SDK工程导入与workspace管理机制

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是MCUXpresso IDE下SDK工程导入与workspace管理机制. MCUXpresso IDE是恩智浦软件团队倾注很大心血研发 ...

  3. MongoDB学习笔记—Linux下搭建MongoDB环境

    1.MongoDB简单说明 a MongoDB是由C++语言编写的一个基于分布式文件存储的开源数据库系统,它的目的在于为WEB应用提供可扩展的高性能数据存储解决方案. b MongoDB是一个介于关系 ...

  4. Mongodb在Windows 7下的安装及配置

    第一步 下载MongoDB: 下载mongodb的windows版本,有32位和64位版本,根据操作系统情况下载,下载地址:http://www.mongodb.org/downloads 解压缩至指 ...

  5. MongoDB介绍与windows下安装

    MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的.他支持的数据结构非常松散,是类 似json的bjson格式,因此可以存储比较复杂的数据类型. ...

  6. MongoDb的bin目录下文件mongod,mongo,mongostat命令的说明及使用

    MongoDB的下载地址:http://www.mongodb.org/downloads. 下载好直接解压安装包,即可使用. bin目录下的几个文件说明: mongo 客户端程序,连接MongoDB ...

  7. MongoDB 介绍及Windows下安装

    一.MongoDB简介 MongoDB是一个高性能,开源,无模式的文档型数据库,是当前NoSql数据库中比较热门的一种.它在许多场景下可用于替代传统的关系型数据库或键/值存储方式.Mongo使用C++ ...

  8. MongoDB深圳用户组线下活动召集

    MongoDB线下用户组是由全世界MongoDB爱好者发起的不定期线下交流活动.目前全球有100多个MongoDB用户组,3万5千多爱好者参与.用户组活动的形式通常会有一到两个MongoDB相关的技术 ...

  9. MongoDB在Linux系统下的安装与启动

    Mongodb介绍 MongoDB是一个开源文档数据库,提供高性能,高可用性和自动扩展,官方文档:https://docs.mongodb.com/manual/introduction/ Mongo ...

随机推荐

  1. FME中通过HTMLExtractor向HTML要数据

    如何不断扩充数据中心的数据规模,提升数据挖掘的价值,这是我们思考的问题,数据一方面来自于内部生产,一部分数据可以来自于互联网,互联网上的数据体量庞大,形态多样,之前blog里很多FMEer已经提出了方 ...

  2. 【网站管理1】_dede织梦后台如何发布文章

    对于新手可能不了解,dede织梦后台是如何发文章的.下面说下我的经验. 发布文章步骤 1.打开浏览器,推介谷歌,360极速浏览器,火狐浏览器,输入网站后台网址   出现如下图登入界面 2.输入账号密码 ...

  3. Oracle 12C 新特性之move (非分区表)table online

    以前版本中move table不能够online, move 会引rowid改变使对应的索引失效. 12c 中 alter table move online不会对新事务阻塞同时会自动的维护索引的有效 ...

  4. SQL Server中INNER JOIN与子查询IN的性能测试

    这个月碰到几个人问我关于"SQL SERVER中INNER JOIN 与 IN两种写法的性能孰优孰劣?"这个问题.其实这个概括起来就是SQL Server中INNER JOIN与子 ...

  5. Swift学习笔记(4):字符串

    目录: 初始化 常用方法或属性 字符串索引 初始化 创建一个空字符串作为初始值: var emptyString = "" // 空字符串字面量 var anotherEmptyS ...

  6. 【JAVAWEB学习笔记】24_filter实现自动登录和解决全局的编码问题

    过滤器Filter 学习目标 案例-自动登录 案例-解决全局的编码 一.过滤器Filter 1.filter的简介 filter是对客户端访问资源的过滤,符合条件放行,不符合条件不放行,并且可以对目标 ...

  7. 基于dubbo的SSM(Spring,SpringMvc,Mybatis)整合的Maven多工程(下)

    上篇是SSM的maven单工程(http://www.cnblogs.com/yuanjava/p/6748956.html).中篇是 SSM的maven多工程(http://www.cnblogs. ...

  8. Weighted Effect Coding: Dummy coding when size matters

    If your regression model contains a categorical predictor variable, you commonly test the significan ...

  9. 一天搞定CSS:定位position--17

    1.定位取值概览 2.相对定位relative <!DOCTYPE html> <html> <head> <meta charset="UTF-8 ...

  10. python中defaultdict的用法

    初识defaultdict 之前在使用字典的时候, 用的比较随意, 只是简单的使用dict. 然而这样在使用不存在的key的时候发生KeyError这样的一个报错, 这时候就该defaultdict登 ...