详细讲解Quartz.NET

sched.ScheduleJob(job, trigger);

Thread.Sleep(30 * 1000);

namespace QuartzBeginnerExample

using Common.Logging;

catch (ThreadInterruptedException)

然则,因为调度程序音信是储存在被分配在内存里面,所以,当应用程序停止运行时,所有调度音讯将被丢掉。假使您需求在重复开动之间持久化调度新闻,则将需要第三种档次的课业存储。为了修正这一个难点,Quartz.NET
提供了 AdoJobStore。顾名思义,作业仓库通过
ADO.NET把具有数据放在数据库中。数据持久性的代价就是性质下落和错综复杂的增长。它将享有的多少经过ADO.NET保存到数据库可中。它的布置要比RAMJobStore稍微复杂,同时速度也并未那么快。可是品质的症结不是老大差,尤其是假使你在数额库表的主键上成立目录。

/// Called by the <see cref=”IScheduler” /> when a

trigger = new SimpleTrigger(“trig_” + count, schedId, 20, 4000L);

// ask scheduler to re-Execute this job if it was in progress when

JobDetail job = new JobDetail(“job_” + count, schedId,
typeof(SimpleQuartzJob));

using System.Collections.Generic;

_log.Info(“——- Scheduling Jobs ——————“);

0 15 10 ? * 6L 2007-2010

}

using Quartz.Impl;

}

ISchedulerFactory sf = new StdSchedulerFactory();

末段的疑云就是什么树立获得数据库联网的数据源(DataSource)。Quartz属性中定义数据源是通过提供所有连接数据库的新闻,让Quartz自己成立和管理数据源。

上边的表达式

ISchedulerFactory sf = new StdSchedulerFactory();

JobDetail job = new JobDetail(“job1”, “group1”,
typeof(SimpleQuartzJob));

// All of the jobs have been added to the scheduler, but none of the
jobs

l SqlServer-20 – SQL Server driver for .NET Framework 2.0

获取Quartz.net     Download
Quartz
:.NET应用程序的开放源码作业调度解决方案

sched.Start();

}

get { return GetType().Name; }

下一场必要安装JobStore所使用的数据源。必须在Quartz属性中定义已命名的数据源,比如,大家指定Quartz使用名为”default”的数据源(在配置文件的别样地方定义)。

{

// First we must get a reference to a scheduler

最后,须求配备数据源的接纳的Ado.net数据提供者和数据库连接串,数据库连接串是专业的Ado.net
数据库连接的连日串。数据库提供者是关周密据库同Quartz.net之间保持低耦合的数据库的连年提供者.

l MySql-50 – MySQL Connector/.NET v. 5.0 (.NET 2.0)

// ask scheduler to re-Execute this job if it was in progress when

log.Info(“——- Starting Scheduler —————-“);

{

清单 3 突显了 CronTrigger 的一个示范。请留意 SchedulerFactory、Scheduler
和 JobDetail 的实例化,与 SimpleTrigger
示例中的实例化是一律的。在那么些示例中,只是修改了触发器。那里指定的 cron
表明式(“0/5 * * * * ?”)安插义务每 5 秒执行两回。

// will run until the scheduler has been started

}

public string Name

sched.ScheduleJob(job, trigger);

log.Info(“——- Initializing ——————-“);

<add key=”quartz.threadPool.type”
value=”Quartz.Simpl.SimpleThreadPool, Quartz” />

// executing…

}

// the scheduler went down…

try

_log.Info(“——- Starting Scheduler —————“);

properties[“quartz.jobStore.clustered”] = “true”;

example.Run(clearJobs, scheduleJobs);

清单3 CronTriggerRunner.cs

e2.RefireImmediately = true;

不无的域中的值都有一定的合法范围,这么些值的法定范围至极显明,例如:秒和分域的合法值为0到59,小时的合法范围是0到23,Day-of-Month中值得合法凡范围是0到31,可是急需专注分裂的月份中的天数不一样。月份的官方值是0到11。或者用字符串JAN,FEB
MAR, APR, MAY, JUN, JUL, AUG, SEP, OCT, NOV
及DEC来代表。Days-of-Week可以用1到7来代表(1=星期天)或者用字符串SUN,
MON, TUE, WED, THU, FRI 和SAT来表示.

     Quartz.NET是一个开源的课业调度框架,是OpenSymphony 的 Quartz
API的.NET移植,它用C#写成,可用来winform和asp.net应用中。它提供了惊天动地的油滑而不就义简单性。你可以用它来为履行一个功课而创办简单的或复杂的调度。它有过多特性,如:数据库援救,集群,插件,帮忙cron-like表明式等等。

// It will run 10 time and exhaust.

{

for (int j = 0; j < names.Length; j++)

namespace QuartzBeginnerExample

}

要使用AdoJobStore(假定使用StdSchedulerFactory),首先须要设置Quartz配置中的quartz.jobStore.type属性为Quartz.Impl.AdoJobStore.JobStoreTX,
Quartz。

SimpleTrigger trigger = new SimpleTrigger(“trigger1”, “group1”);

}

SQL Server,如上所示,只用作业和触发器,就能访问多量的功能。可是,Quartz
是个增加而灵活的调度包,对于甘愿钻研它的人来说,它还提供了越来越多效益。下一节研讨Quartz 的片段高等特性。

public virtual void Run()

job = new JobDetail(“job_” + count, schedId, typeof(SimpleQuartzJob));

<configSections>

‘?’字符可以用在day-of-month及day-of-week域中,它用来代表“没有指定值”。那对于必要指定一个照旧八个域的值而不需求对其它域举行设置来说卓殊实用。

结束语

trigger = new SimpleTrigger(“trig_” + count, schedId, 20, 5000L);

清单4 AdoJobStoreRunner.cs

job = new JobDetail(“job_” + count, schedId, typeof(SimpleQuartzJob));

trigger = new SimpleTrigger(“trig_” + count, schedId, 20, 4500L);

Cron表明式被用来安插CronTrigger实例。Cron表达式是一个由7个子表达式组成的字符串。每个子表明式都讲述了一个独门的日程细节。那些子表达式用空格分隔,分别代表:

SchedulerMetaData metaData = sched.GetMetaData();

_log.Info(“——- Shutdown Complete —————-“);

用作一个例子,上面的Quartz.NET克隆表明式将在星期一到周日的每日中午10点15分执行一个学业。

properties[“quartz.jobStore.driverDelegateType”] =
“Quartz.Impl.AdoJobStore.StdAdoDelegate, Quartz”;

清单 2 中的 SimpleTrigger 显示了触发器的底子:

catch (Exception e)

DateTime ts = TriggerUtils.GetNextGivenSecondDate(null, 15);

// the scheduler went down…

SimpleTrigger trigger = new SimpleTrigger(“trig_” + count, schedId, 20,
5000L);

properties[“quartz.jobStore.dataSource”] = “default”

public class SimpleQuartzJob : IJob

{

try

public class AdoJobStoreRunner : IExample

/// <summary>

properties[“quartz.threadPool.type”] = “Quartz.Simpl.SimpleThreadPool,
Quartz”;

作业一旦被调度,调度器须要牢记并且跟踪作业和它们的执行次数。假设您的课业是30分钟后或每30秒调用,这不是很有用。事实上,作业执行须求格外纯粹和及时调用在被调度作业上的Execute()方法。Quartz通过一个称作作业存储(JobStore)的概念来做作业存储和管制。

{

清单2 SimpleTriggerRunner.cs

using System;

}

// will run until the scheduler has been started

{

try

properties[“quartz.scheduler.instanceId”] = “instance_one”;

// display some stats about the schedule that just ran

sched.Start();

{

}

}

接下去,须求为JobStore指定所运用的数据库表前缀(前边议论过)。

using Quartz;

{

public virtual void CleanUp(IScheduler inScheduler)

l OracleClient-20 – Microsoft’s Oracle Driver (comes bundled with .NET
Framework)

_log.Info(“——- Waiting for one hour… ———-“);

SchedulerMetaData metaData = sched.GetMetaData();

Quartz.net 作业调度框架所提供的 API
在两上边都表现极佳:既周密强大,又便于使用。Quartz
可以用于不难的学业触发,也得以用来复杂的 Ado.net持久的课业存储和进行。

public class SimpleTriggerRunner

{

for (int i = 0; i < groups.Length; i++)

// All of the jobs have been added to the scheduler, but none of the

<?xml version=”1.0″ encoding=”utf-8″ ?>

{

{

log.Info(“——- Initialization Complete ——–“);

l MySql-51 – MySQL Connector/:NET v. 5.1 (.NET 2.0)

// This job simply prints out its job name and the

trigger.StartTime = (DateTime.Now.AddMilliseconds(2000L));

using System.Collections.Generic;

}

{

_log.Warn(“***** Deleting existing jobs/triggers *****”);

// ask scheduler to re-Execute this job if it was in progress when

public virtual void Execute(JobExecutionContext context)

// this job will refire immediately

透过兑现 Quartz.IJob接口,可以使 .NET 类变成可实施的。清单 1 提供了
Quartz.IJob作业的一个演示。这些类用一条极度简单的出口语句覆盖了
Execute(JobExecutionContext context)
方法。这么些办法可以涵盖大家想要执行的任何代码(所有的代码示例都根据Quartz.NET 0.6 ,它是编写这篇文章时的自贡久安发行版)。

l MySql-109 – MySQL Connector/.NET v. 1.0.9

// jobs don’t start firing until start() has been called…

properties[“quartz.jobStore.type”] =
“Quartz.Impl.AdoJobStore.JobStoreTX, Quartz”;

_log.Info(string.Format(“{0} will run at: {1} and repeat: {2} times,
every {3} seconds”, job.FullName, trigger.GetNextFireTime(),
trigger.RepeatCount, (trigger.RepeatInterval / 1000)));

sched.ScheduleJob(job, trigger);

Thread.Sleep(300 * 1000);

ISchedulerFactory sf = new StdSchedulerFactory(properties);

<add key=”quartz.scheduler.instanceName”
value=”ExampleDefaultQuartzScheduler” />

}

配备 AdoJobStore使用数据持续的名字

金榜题名地,如果您需求在给定的年月和重新次数或者几次燃烧之间等待的秒数打火一个作业,那么SimpleTrigger适合你。另一方面,若是你有许多扑朔迷离的学业调度,那么可能需要CronTrigger。

<add key=”quartz.threadPool.threadPriority” value=”2″ />

log.Info(“——- Waiting 30 seconds… ————–“);

string schedId = sched.SchedulerInstanceId;

public class CronTriggerRunner

using System.Collections.Generic;

log.Info(“——- Waiting five minutes… ————“);

public virtual void Run(bool inClearJobs, bool inScheduleJobs)

Quartz.NET框架的主干是调度器。调度器负责管理Quartz.NET应用运行时环境。调度器不是靠自己做有所的劳作,而是依靠框架内局地格外关键的预制构件。Quartz不仅仅是线程和线程管理。为有限支撑可伸缩性,Quartz.NET选拔了根据十二线程的架构。
启动时,框架起先化一套worker线程,那套线程被调度器用来施行预订的功课。那就是Quartz.NET怎么着能并发运行四个作业的法则。Quartz.NET重视一套松耦合的线程池管理部件来治本线程环境。作业是一个实践任务的简单.NET类。义务可以是其他C#\VB.NET代码。只需你兑现Quartz.IJob接口并且在产出严重错误景况下抛出JobExecutionException极度即可。

if (inClearJobs)

}

properties[“quartz.threadPool.threadCount”] = “5”;

trigger.RepeatCount = 100;

catch (ThreadInterruptedException)

quartz.jobStore.tablePrefix = QRTZ

ILog log = LogManager.GetLogger(typeof(SimpleTriggerExample));

{

sched.AddJob(job, true);

<configuration>

</configSections>

private static ILog _log =
LogManager.GetLogger(typeof(SimpleQuartzJob));

卓有成效作业存储

job.RequestsRecovery = (true);

}

Thread.Sleep(TimeSpan.FromHours(1));

count++;

DateTime ft = sched.ScheduleJob(trigger);

public virtual void Run()

</quartz>

配置AdoJobStore的数据库表前缀

_log.Info(string.Format(“{0} will run at: {1} & repeat: {2}/{3}”,
job.FullName, trigger.GetNextFireTime(), trigger.RepeatCount,
trigger.RepeatInterval));

properties[“quartz.dataSource.default.provider”] = “SqlServer-20”;

Quartz.NET设计者做了一个布置采用来从调度分离开作业。Quartz.NET中的触发器用来告诉调度程序作业曾几何时接触。框架提供了一把触发器类型,但八个最常用的是SimpleTrigger和CronTrigger。SimpleTrigger为急需不难打火调度而安顿。

IScheduler sched = sf.GetScheduler();

// set its start up time

为了有利于读者,大家选拔Quartz.NET的事例代码来解释,现在来看一下 Quartz
API 的显要组件。

if (inScheduleJobs)

bool scheduleJobs = true;

// jobs

bool clearJobs = true;

布局AdoJobStore使用数据持续的数据库连接串和数据库提供者

quartz.threadPool.type = Quartz.Simpl.SimpleThreadPool, Quartz

log.Info(“——- Scheduling Jobs —————-“);

sched.Start();

{

// if running MS SQL Server we need this

// jobs can be scheduled before sched.start() has been called

}

using System;

trigger.StartTime = (DateTime.Now.AddMilliseconds(1000L));

properties[“quartz.jobStore.misfireThreshold”] = “60000”;

trigger.StartTime = DateTime.Now.AddMilliseconds(1000L);

}

sched.ScheduleJob(job, trigger);

设置AdoJobStore

string jobName = context.JobDetail.FullName;

using Quartz;

NameValueCollection properties = new NameValueCollection();

调度器和学业

AdoJobStore大概可以在此外数据库上行事,它宽广地应用Oracle, MySQL, MS
SQLServer2000, HSQLDB, PostreSQL 以及
DB2。要运用AdoJobStore,首先必须创设一套Quartz使用的多少库表,可以在Quartz
的database\tables找到创设库表的SQL脚本。假如没有找到您的数据库类型的台本,那么找到一个已有些,修改成为你数据库所急需的。必要专注的一件工作就是富有Quartz库表名都以QRTZ_作为前缀(例如:表”QRTZ_TRIGGERS”,及”QRTZ_JOB_DETAIL”)。实际上,可以你可以将前缀设置为其他你想要的前缀,只要您告知AdoJobStore这个前缀是怎么着即可(在你的Quartz属性文件中安顿)。对于一个数据库中采用多少个scheduler实例,那么配置差其余前缀可以成立多套库表,万分卓有成效。

l MySql-10 – MySQL Connector/.NET v. 1.0.7

// schedule it to run!

{

<add key=”quartz.threadPool.threadCount” value=”10″ />

// set the interval, how often the job should run (10 seconds here)

}

trigger.StartTime = (DateTime.Now.AddMilliseconds(1000L));

job.RequestsRecovery = (true);

/// </summary>

// First we must get a reference to a scheduler

<add key=”quartz.jobStore.type” value=”Quartz.Simpl.RAMJobStore,
Quartz” />

trigger.CronExpressionString = “0/20 * * * * ?”;

using System.Threading;

log.Info(string.Format(“Executed {0} jobs.”, metaData.NumJobsExecuted));

job = new JobDetail(“job_” + count, schedId, typeof(SimpleQuartzJob));

<quartz>

using System.Text;

// the scheduler went down…

下一步,需求为JobStore 选取一个DriverDelegate ,
DriverDelegate负责做指定数据库的有着ADO.NET工作。StdADO.NETDelegate是一个选用vanilla”
ADO.NET代码(以及SQL语句)来成功工作的代理。要是数据库没有其他指定的代办,那么就试用那个代理。唯有当使用StdADO.NETDelegate暴发难点时,我们才会使用数据库特定的代办(那看起来卓殊开朗。其余的代理可以在Quartz.Impl.AdoJobStor命名空间找到。)。其余的代办包蕴PostgreSQLDelegate
( 专为PostgreSQL 7.x)。

properties[“quartz.threadPool.threadPriority”] = “Normal”;

}

</configuration>

job = new JobDetail(“job_” + count, schedId, typeof(SimpleQuartzJob));

设若选用好了代理,就将它的名字设置给AdoJobStore。

using System.Text;

job.RequestsRecovery = (true);

DateTime ft = sched.ScheduleJob(job, trigger);

for (int j = 0; j < names.Length; j++)

// ask scheduler to re-Execute this job if it was in progress when

// wait five minutes to show jobs

}

log.Info(“——- Shutdown Complete —————–“);

using Common.Logging;

properties[“quartz.jobStore.tablePrefix”] = “QRTZ_”;

string[] groups = inScheduler.TriggerGroupNames;

properties[“quartz.jobStore.useProperties”] = “false”;

清单 4 显示了
AdoJobStore提供的数码持久性。如同在前方的示范中一律,先从伊始化
SchedulerFactory 和 Scheduler
伊始。然后,不再须求初阶化作业和触发器,而是要博取触发器群组名称列表,之后对于每个群组名称,获取触发器名称列表。请留心,每个现有的课业都应该用
Scheduler. RescheduleJob ()
方法重新调度。仅仅重新开首化在在此之前的应用程序运行时停下的作业,不会正确地装载触发器的特性。

示例下载 HTTP 
基于 Quartz.net 的示例 (C#代码 )   QuartzBeginnerExample.zip   
324KB  

JobDetail job = new JobDetail(“job1”, “group1”, typeof(SimpleJob));

}

ILog log = LogManager.GetLogger(typeof(CronTriggerRunner));

quartz.dataSource.default.provider= SqlServer-11

此时此刻Quartz.net扶助的以下数据库的数目提供者:

// date and time that it is running

一个cron表明式的例子字符串为”0 0 12 ? *
WED”,那象征“周周四的中午12:00”。

Quartz提供三种基本功课存储类型。第一种档次叫做RAMJobStore,它利用普通的内存来持久化调度程序音讯。那种作业存储类型最不难配置、构造和运行。Quartz.net缺省利用的就是RAMJobStore。对广大施用来说,那种作业存储已经够用了。

// set the number of execution of this job, set to 10 times.

groups = inScheduler.JobGroupNames;

清单 1:作业

log.Info(“——- Initializing ——————-“);

你已经须求动用执行一个职责吗?这么些职务天天或每一周周六晚间11:30,或许只是每个月的尾声一天执行。一个电动执行而无须干预的职责在履行进度中如果暴发一个严重错误,应用可以知到其实施破产并尝试再度履行呢?你和您的团伙是用.NET编程吗?若是这么些题材中其他一个您回复是,那么您应当利用Quartz.NET调度器。
Quartz.NET允许开发人士根据时间距离(或天)来调度作业。它达成了作业和触发器的多对多涉及,还是能把五个作业与分歧的触发器关联。整合了
Quartz.NET的应用程序可以引用来自差异事件的作业,还足以为一个轩然大波组合两个作业.

请留意,Execute 方法接受一个 JobExecutionContext
对象作为参数。那几个目的提供了课业实例的运行时上下文。更加地,它提供了对调度器和触发器的拜会,这两者同盟来启动作业以及学业的
JobDetail 对象的施行。Quartz.NET 通过把作业的境况放在 JobDetail
对象中并让 JobDetail
构造函数启动一个功课的实例,分离了作业的举行和作业周围的情景。JobDetail
对象储存作业的侦听器、群组、数据映射、描述以及学业的其他属性。

inScheduler.DeleteJob(names[j], groups[i]);

‘W’
字符用来指定距离给定日最接近的周几(在day-of-week域中指定)。例如:借使您为day-of-month域指定为”15W”,则象征“距离月尾15号以来的周几”。

还有其余过多艺术可以操纵
SimpleTrigger。除了指定重复次数和重新间隔,仍能指定作业在特定日历时间实施,只需给定执行的最长日子如故优先级(稍后研商)。执行的最长日子足以覆盖指定的重复次数,从而保障作业的运作不会当先最长日子。

‘L’字符可以在day-of-month及day-of-week中接纳,这些字符是”last”的简写,可是在多少个域中的意义差异。例如,在day-of-month域中的”L”表示那个月的尾声一天,即,八月的31日,非闰年的2月的28日。假如它用在day-of-week中,则意味”7″或者”SAT”。然而假如在day-of-week域中,那么些字符跟在其余值前面,则象征”当月的末梢的周XXX”。例如:”6L”
或者
“FRIL”都代表本月的结尾一个周四。当使用’L’选项时,最重点的是不要指定列表或者值范围,否则会招致混乱。

配置 Quartz使用 JobStoreTx

properties[“quartz.scheduler.instanceName”] = “TestScheduler”;

CronTrigger是按照Calendar-like调度的。当您须求在除周五和周天外的每天晚上10点半实施作业时,那么相应利用CronTrigger。正如它的名字所暗示的这样,CronTrigger是基于Unix克隆表明式的。

sched.Shutdown(true);

  1. Seconds 秒

  2. Minutes 分钟

  3. Hours 小时

  4. Day-of-Month 月首的天

  5. Month 月

  6. Day-of-Week 周中的天

  7. Year (optional field) 年(可选的域)

_log.Info(“——- Initialization Complete ———–“);

‘/’字符用来代表值的增量,例如,
假设分钟域中放入’0/15’,它代表“每隔15分钟,从0伊始”,若是在份中域中运用’3/20’,则意味“小时中每隔20分钟,从第3分钟开端”或者别的相同的花样就是’3,23,43’。

{

quartz.dataSource.default.connectionString =
Server=(local);Database=quartz;Trusted_Connection=True;

<section name=”quartz”
type=”System.Configuration.NameValueSectionHandler, System,
Version=1.0.5000.0,Culture=neutral, PublicKeyToken=b77a5c561934e089″
/>

IScheduler sched = sf.GetScheduler();

设若Scheduler卓殊忙(比如,执行的职分数量大致和线程池的数码一样,那么您须要科学地配置DataSource的连日数量为线程池数量。为了提醒AdoJobStore所有的JobDataMaps中的值都是字符串,并且能以“名字-值”对的艺术存储而不是以复杂对象的种类化方式储存在BLOB字段中,应安装
quartz.jobStore.usePropertiess配置参数的值为”true”(那是缺省的方法)。那样做,从深入来看这几个安全,那样防止了对存储在BLOB中的非字符串的系列化对象的类型转换难题。

JobExecutionException e2 = new JobExecutionException(e);

{

将在二零零七年到二〇一〇年的每个月的最后一个星期六晌午10点15分执行作业。你不容许用SimpleTrigger来做那么些事情。你可以用两者之中的其他一个,但哪些跟合适则取决于你的调度需求。

trigger.RepeatInterval = 10000;

l SQLite1044 – SQLite ADO.NET 2.0 Provider v. 1.0.44 (.NET 2.0)

l SqlServer-11 – SQL Server driver for .NET Framework 1.1

String[] names = inScheduler.GetJobNames(groups[i]);

log.Info(string.Format(“{0} will run at: {1} and repeat: {2} times,
every {3} seconds”,

// ask scheduler to re-Execute this job if it was in progress when

for (int i = 0; i < groups.Length; i++)

单个子表明式可以涵盖限制或者列表。例如:前面例子中的周中的天这么些域(那里是”WED”)能够被沟通为”MON-FRI”,
“MON, WED, FRI”或者甚至”MON-WED,SAT”。

作业和触发器:

学业管理和仓储

CleanUp(sched);

public void Run()

log.Info(“——- Shutdown Complete —————–“);

清单 2 初步时实例化一个
SchedulerFactory,获得此调度器。就像前边议论过的,创设 JobDetail
对象时,它的构造函数要承受一个 Job 作为参数。顾名思义,SimpleTrigger
实例分外原始。在创造对象之后,设置多少个基本特性以即时调度任务,然后每 10
秒重复五回,直到作业被实践 100 次。

配置AdoJobStore 使用DriverDelegate

// the scheduler went down…

log.Info(“——- Starting Scheduler —————-“);

log.Info(“——- Shutting Down ———————“);

}

CronTrigger trigger = new CronTrigger(“trigger1”, “group1”, “job1”,
“group1”);

using Quartz.Impl;

trigger.StartTime = ts;

log.Info(string.Format(“{0} has been scheduled to run at: {1} and repeat
based on expression: {2}”, job.FullName, ft.ToString(“r”),
trigger.CronExpressionString));

// wait 30 seconds to show jobs

namespace QuartzBeginnerExample

‘#’表示表示月尾的第多少个周几。例如:day-of-week域中的”6#3″ 或者
“FRI#3″表示“月尾第几个周日”。

properties[“quartz.dataSource.default.connectionString”] =
@”Server=LIJUNNIN-PC\SQLEXPRESS;Database=quartz;Trusted_Connection=True;”;

}

count++;

/// the <see cref=”IJob” />.

要是数据库表已经创办,在配备和启动AdoJobStore此前,就必要作出一个进一步首要的决定。你要控制在您的运用中要求怎样项目标业务。如若不想将scheduling命令绑到其他的业务上,那么您可以因而对JobStore使用JobStoreTX来让Quartz帮你管理工作(那是最广泛的选取)。

_log.Info(string.Format(“{0} will run at: {1} and repeat: {2} times,
every {3} seconds”, job.FullName, trigger.GetNextFireTime(),
trigger.RepeatCount, (trigger.RepeatInterval / 1000)));

int count = 1;

IJob接口包涵唯一的一个方法Execute(),作业从此处先导施行。一旦落到实处了IJob接口和Execute
()方法,当Quartz.NET确定该是作业运行的时候,它将调用你的课业。Execute()方法内就完全是你要做的作业。

// get a “nice round” time a few seconds in the future…

{

job.RequestsRecovery = (true);

trigger.StartTime = (DateTime.Now.AddMilliseconds(1000L));

job.FullName, ft.ToString(“r”), trigger.RepeatCount,
(trigger.RepeatInterval / 1000)));

IScheduler sched = sf.GetScheduler();

// job1 will only fire once at date/time “ts”

_log.Info(“Executing job: ” + jobName + ” executing at ” +
DateTime.Now.ToString(“r”));

log.Info(“——- Scheduling Jobs —————-“);

_log.Info(“— Error in job!”);

String[] names = inScheduler.GetTriggerNames(groups[i]);

count++;

{

sched.Shutdown(true);

// jobs can be scheduled before sched.start() has been called

throw e2;

{

AdoJobStoreRunner example = new AdoJobStoreRunner();

using System;

_log.Info(string.Format(“{0} will run at: {1} and repeat: {2} times,
every {3} seconds”, job.FullName, trigger.GetNextFireTime(),
trigger.RepeatCount, (trigger.RepeatInterval / 1000)));

要开端使用 Quartz.NET,必要用 Quartz.NET API 对品种展开布局。步骤如下:

// job 1 will run every 20 seconds

Quartz.NET入门

properties[“quartz.jobStore.dataSource”] = “default”;

{

log.Info(“——- Initialization Complete ——–“);

count++;

通配符(’*’)可以被用来表示域中“每个”可能的值。由此在”Month”域中的*代表每个月,而在Day-Of-Week域中的*则表示“周中的每日”。

log.Info(string.Format(“Executed {0} jobs.”, metaData.NumJobsExecuted));

using System.Text;

}

{

  1. http://quartznet.sourceforge.net/download.html下载 Quartz.NET
    API,最新版本是0.6

  2. 解压缩Quartz.NET-0.6.zip 到目录,依据你的门类意况用Visual Studio
    2003依然Visual Studio
    2005打开相应工程,编译。你可以将它放进自己的使用中。Quartz.NET框架只必要少数的第三方库,并且那几个三方库是少不了的,你很可能早就在接纳那几个库了。

log.Info(“——- Started Scheduler —————–“);

trigger = new SimpleTrigger(“trig_” + count, schedId, 20, 3000L);

log.Info(“——- Shutting Down ———————“);

{

3.
在Quartz.NET有一个誉为quartz.properties的配置文件,它同意你改改框架运行时环境。缺省是行使Quartz.dll里面的quartz.properties文件。当然你可以在应用程序配置文件中做相应的布局,上边是一个布署文件示例:

_log.Info(“——- Started Scheduler —————-“);

inScheduler.UnscheduleJob(names[j], groups[i]);

l OracleODP-20 – Oracle’s Oracle Driver

log.Info(“——- Started Scheduler —————–“);

quartz.threadPool.type = Quartz.Simpl.SimpleThreadPool, Quartz

     前言:7月份翻译了Quartz.NET的合法课程:开源的学业调度框架 –
Quartz.NET
,
有的朋友抱怨难用,确实,近来Qiartz.NET的流行版本依旧0.6,还设有重重bug和不到家的地点。本文使用一种种代码示例介绍
Quartz.NET API,演示它的建制,例如作业、触发器、作业仓库。

job.RequestsRecovery = true;

// unschedule jobs

// the scheduler went down…

// executing…

// delete jobs

// First we must get a reference to a scheduler

using Common.Logging;

private static ILog _log =
LogManager.GetLogger(typeof(AdoJobStoreRunner));

/// <see cref=”Trigger” /> fires that is associated with

}

properties[“quartz.jobStore.selectWithLockSQL”] = “SELECT * FROM
{0}LOCKS UPDLOCK WHERE LOCK_NAME = @lockName”;

{

using Quartz;

<add key=”quartz.jobStore.misfireThreshold” value=”60000″ />

0 15 10 ? * MON-FRI

_log.Info(string.Format(“{0} will run at: {1} & repeat: {2}/{3}”,
job.FullName, trigger.GetNextFireTime(), trigger.RepeatCount,
trigger.RepeatInterval));

sched.Shutdown();

_log.Info(“——- Shutting Down ——————–“);

sched.ScheduleJob(job, trigger);

相关文章