JobStore
负责保持对所有
scheduler
“
工作数据
”
追踪,这些工作数据包括:
job
(任务)
,trigger
(触发器)
,calendar(
日历
)
等。为你的
Quartz scheduler
选择合适的
JobStore
是非常重要的一步,幸运的是,如果你理解了不同的
JobStore
之间的差别,那么选择就变得非常简单。在提供产生
scheduler
实例的
SchedulerFactory
的属性文件中声明
scheduler
所使用的
JobStore
(以及它的配置)。
注:不要在代码中直接使用
JobStore
实例,处于某些原因,很多人试图这么做。
JobStore
是由
Quartz
自身在幕后使用。你必须告诉(通过配置)
Quartz
使用哪个
JobStore
,而你只是在你的代码中使用
Scheduler
接口完成工作。
RAMJobStore
RAMJobStore
是最简单的
JobStore
,也是性能最好的(根据
CPU
时间)。从名字就可以直观地看出,
RAMJobStore
将所有的数据都保存在
RAM
中。这就是为什么它闪电般的快速和如此容易地配置。缺点就是当应用结束时所有的日程信息都会丢失,这意味着
RAMJobStore
不能满足
Jobs
和
Triggers
的持久性(
“
non-volatility
”
)。对于有些应用来说,这是可以接受的,甚至是期望的行为。但是对于其他应用来说,这将是灾难。
为了使用RAMJobStore(假设你使用DirectSchedulerFactory),指使简单地将类名Quartz.Simpl.RAMJobStore作为你的quartz的配置值。
配置 Quartz 使用 RAMJobStore
<
quartz
>
<
add
key
=
"quartz.jobStore.type" value="Quartz.Simpl.RAMJobStore, Quartz" />
quartz
>
这里没有其他需要的担心的配置。 Qiartz.net缺省使用的就是RAMJobStore.
ADO.NET Job Store (AdoJobStore)
基于
ADO.NET
的
job store
目前正在开发中,还存在很多的
bug.
从
0.6
版本开始
AdoJobStore
基本上可以用了
.
AdoJobStore
的命名也非常得体,它将所有的数据通过
ADO.NET
保存到数据库可中。它的配置要比
RAMJobStore
稍微复杂,同时速度也没有那么快。但是性能的缺陷不是非常差,尤其是如果你在数据库表的主键上建立索引。
AdoJobStore
几乎可以在任何数据库上工作,它广泛地使用
Oracle, MySQL, MS SQLServer2000, HSQLDB, PostreSQL
以及
DB2
。要使用
AdoJobStore
,首先必须创建一套
Quartz
使用的数据库表,可以在
Quartz
的
database\tables
找到创建库表的
SQL
脚本。如果没有找到你的数据库类型的脚本,那么找到一个已有的,修改成为你数据库所需要的。需要注意的一件事情就是所有
Quartz
库表名都以
QRTZ_
作为前缀(例如:表
"QRTZ_TRIGGERS",
及
"QRTZ_JOB_DETAIL"
)。实际上,可以你可以将前缀设置为任何你想要的前缀,只要你告诉
AdoJobStore
那个前缀是什么即可(在你的
Quartz
属性文件中配置)。对于一个数据库中使用多个
scheduler
实例,那么配置不同的前缀可以创建多套库表,十分有用。
一旦数据库表已经创建,在配置和启动
AdoJobStore
之前,就需要作出一个更加重要的决策。你要决定在你的应用中需要什么类型的事务。如果不想将
scheduling
命令绑到其他的事务上,那么你可以通过对
JobStore
使用
JobStoreTX
来让
Quartz
帮你管理事务(这是最普遍的选择)。
最后的疑问就是如何建立获得数据库联接的数据源(
DataSource
)。
Quartz
属性中定义数据源是通过提供所有联接数据库的信息,让
Quartz
自己创建和管理数据源。
要使用AdoJobStore(假定使用StdSchedulerFactory),首先需要设置Quartz配置中的quartz.jobStore.type属性为Quartz.Impl.AdoJobStore.JobStoreTX, Quartz。
配置 Quartz使用 JobStoreTx
quartz.threadPool.type
=
Quartz.Simpl.SimpleThreadPool, Quartz
下一步,需要为
JobStore
选择一个
DriverDelegate
,
DriverDelegate
负责做指定数据库的所有
ADO.NET
工作。
StdADO.NETDelegate
是一个使用
vanilla" ADO.NET
代码(以及
SQL
语句)来完成工作的代理。如果数据库没有其他指定的代理,那么就试用这个代理。只有当使用
StdADO.NETDelegate
发生问题时,我们才会使用数据库特定的代理(这看起来非常乐观。其他的代理可以在Quartz.Impl.AdoJobStor命名空间找到。)。其他的代理包括
PostgreSQLDelegate (
专为
PostgreSQL 7.x)
。
一旦选择好了代理,就将它的名字设置给
AdoJobStore
。
配置AdoJobStore 使用DriverDelegate
quartz.threadPool.type
= Quartz.Simpl.SimpleThreadPool, Quartz
接下来,需要为
JobStore
指定所使用的数据库表前缀(前面讨论过)。
配置AdoJobStore的数据库表前缀
quartz.jobStore.tablePrefix
=
QRTZ
然后需要设置
JobStore
所使用的数据源。必须在
Quartz
属性中定义已命名的数据源,比如,我们指定
Quartz
使用名为
"default"
的数据源(在配置文件的其他地方定义)。
配置 AdoJobStore使用数据源源的名字
properties[
"quartz.jobStore.dataSource"
] =
"default"
最后,需要配置数据源的使用的Ado.net数据提供者和数据库连接串,数据库连接串是标准的Ado.net 数据库连接的连接串。数据库提供者是关系数据库同Quartz.net之间保持低耦合的数据库的连接提供者。
配置AdoJobStore使用数据源源的数据库连接串和数据库提供者
quartz.dataSource.default.connectionString = Server=(local);Database=quartz;Trusted_Connection=True;
quartz.dataSource.default.provider= SqlServer-11
目前Quartz.net支持的以下数据库的数据提供者:
- SqlServer-11 - SQL Server driver for .NET Framework 1.1
- SqlServer-20 - SQL Server driver for .NET Framework 2.0
- OracleClient-20 - Microsoft's Oracle Driver (comes bundled with .NET Framework)
- OracleODP-20 - Oracle's Oracle Driver
- MySql-10 - MySQL Connector/.NET v. 1.0.7
- MySql-109 - MySQL Connector/.NET v. 1.0.9
- MySql-50 - MySQL Connector/.NET v. 5.0 (.NET 2.0)
- MySql-51 - MySQL Connector/:NET v. 5.1 (.NET 2.0)
- SQLite1044 - SQLite ADO.NET 2.0 Provider v. 1.0.44 (.NET 2.0)
如果Scheduler非常忙(比如,执行的任务数量差不多
和线程池的数量相同,那么你需要正确地配置
DataSource
的连接数量为线程池数量。
为了指示
AdoJobStore
所有的
JobDataMaps
中的值都是字符串,并且能以
“
名字
-
值
”
对的方式存储而不是以复杂对象的序列化形式存储在
BLOB
字段中,应设置
quartz.jobStore.useProperties
配置参数的值为
"true"(
这是缺省的方式
)
。这样做,从长远来看非常安全,这样避免了对存储在
BLOB
中的非字符串的序列化对象的类型转换问题。
自由、创新、研究、探索……