2

我知道quartz.net和codeplex 任务调度程序管理的包装器项目。他们有相当不错的学习曲线和研发阶段,可以让它按照我们的规格工作。将它们打包并使用我们的运行时安装程序进行配置是另一个问题。所以我们决定使用商业 .NET 任务调度程序。

我们的要求是:

  1. Win xp 和 Win 7 (x86 + x64) 必须支持
  2. 触发触发器时必须提供回调或事件。

示例伪代码:

Trigger mytrigger = new Trigger(Daily, "8:00am", myCallbackDelegate);
mytrigger.Start();

每天 8:00 将调用 myCallbackDelegate 指向的方法。

调度程序可以作为服务运行,也可以在每次启动引用它的应用程序时运行。.NET 组件,可以放在表单上并配置为首选。

请提供您的建议。我用谷歌搜索,找不到任何可以完成这个基本功能的东西。谢谢

4

1 回答 1

2

我在 WCF 服务中使用了 Quartz.Net,效果非常好,由于 Cron 触发器,它具有很大的灵活性,基本上你可以解决大多数调度场景,当你调度触发器时,你需要指定一种实现 IJob 接口的类。在我的例子中,Execute 方法调用一个单例类/方法来完成它需要执行的工作。您可以将触发器配置为存储在 RAM(易失性)或数据库上,我认为您可以指定自定义存储,但我没有这样做。

这个问题描述了我在 Quartz.NET 上遇到的唯一问题我还发布了我制定的解决方案,如果您有更具体的问题,请告诉我。

这是 Quartz.NET 的一些配置基础知识,大部分来自教程

要实例化调度程序,您可以执行以下操作:

ISchedulerFactory schedulerFactory = new StdSchedulerFactory();
_scheduler = schedulerFactory.GetScheduler();
_scheduler.Start()

为了安排工作,你会做这样的事情

JobDetail jobDetail = new JobDetail("UNIQUE NAME", null, typeof(NotepadJob));
SimpleTrigger triggerToReturn = new SimpleTrigger();
triggerToReturn.StartTimeUtc = DateTime.Now.ToUniversalTime();
_scheduler.ScheduleJob(jobDetail,trigger);

工作将是这样的

internal class NotepadJob : IJob
{
    //Open Notepad
}

如果使用 SQL 工作,您可以在 Config 文件中配置如下设置:

  <configSections>
      <section name="quartz" type="System.Configuration.NameValueSectionHandler, System, Version=1.0.5000.0,Culture=neutral, PublicKeyToken=b77a5c561934e089" />
  <\configSections>


<quartz>
  <add key="quartz.scheduler.instanceName" value="DefaultQuartzJobScheduler" />
  <add key="quartz.scheduler.instanceId" value="AUTO" />
  <add key="quartz.jobstore.clustered" value="true" />
  <add key="quartz.jobstore.clusterCheckinInterval" value="15000" />
  <add key="quartz.threadPool.type" value="Quartz.Simpl.SimpleThreadPool, Quartz" />
  <add key="quartz.jobStore.useProperties" value="false" />
  <add key="quartz.jobStore.type" value="Quartz.Impl.AdoJobStore.JobStoreTX, Quartz" />
  <add key="quartz.jobStore.driverDelegateType" value="Quartz.Impl.AdoJobStore.SqlServerDelegate, Quartz" />
  <add key="quartz.jobStore.tablePrefix" value="QRTZ_" />
  <add key="quartz.jobStore.lockHandler.type" value="Quartz.Impl.AdoJobStore.UpdateLockRowSemaphore, Quartz" />
  <add key="quartz.jobStore.misfireThreshold" value="60000" />
  <add key="quartz.jobStore.dataSource" value="default" />
  <add key="quartz.dataSource.default.connectionString" value="[CONNECTION STRING]" />
  <add key="quartz.dataSource.default.provider" value="SqlServer-20" />
  <add key="quartz.threadPool.threadCount" value="10" />
</quartz>

-问候

于 2011-05-12T17:13:48.723 回答