使用SQL Server AdoJobStore配置Quartz.NET

时间:2013-07-04 14:59:48

标签: c# .net quartz-scheduler quartz.net

我在尝试让Quartz.NET与AdoJobStore一起工作时遇到了麻烦。这里没有其他问题似乎遇到了我的问题。我能够在没有AdoJobStore配置的情况下使其工作正常,但是最终会保留所有内容,但是在尝试GetScheduler()时我遇到了一个我无法弄清楚的错误。

这是我的石英app.config部分:

<quartz>
   <add key="quartz.scheduler.instanceName" value="XxxDefaultQuartzScheduler"/>
   <add key="quartz.scheduler.instanceId" value="instance_one"/>

   <add key="quartz.threadPool.type" value="Quartz.Simpl.SimpleThreadPool, Quartz"/>
   <add key="quartz.threadPool.threadCount" value="10"/>
   <add key="quartz.threadPool.threadPriority" value="1"/>

   <add key="quartz.jobStore.type" value="Quartz.Impl.AdoJobStore.JobStoreTX, Quartz"/>
   <add key="quartz.jobStore.misfireThreshold" value="60000"/>      
   <add key="quartz.jobStore.dataSource" value="default"/>
   <add key="quartz.jobStore.driverDelegateType" value="Quartz.Impl.AdoJobStore.SqlServerDelegate, Quartz"/>        
   <add key="quartz.jobStore.lockHandler.type" value="Quartz.Impl.AdoJobStore.UpdateLockRowSemaphore, Quartz"/>
   <add key="quartz.jobStore.tablePrefix" value="QRTZ_"/>

   <add key="quartz.dataSource.default.connectionString" value="Server=(local);Database=Quartz;UID=XXXX;PWD=XXXX"/>
   <add key="quartz.dataSource.default.provider" value="SqlServer-20"/>
   <add key="quartz.dataSource.useProperties" value="true"/>
</quartz>

这是相关的初始化代码:

var config = (NameValueCollection) ConfigurationManager.GetSection("quartz");

ISchedulerFactory factory = new StdSchedulerFactory(config);

// This is where an ArgumentOutOfRange exception occurs:
IScheduler scheduler = factory.GetScheduler();

我得到的错误是ArgumentOutOfRangeException

  

长度不能小于零。\ r \ n参数名称:长度

单步执行代码,我可以验证配置部分是否正确读取,并且我检查拼写错误和配置属性的大写错误。我已经验证了数据库可以通过我拥有的connectionString访问。

在执行代码并检查立即窗口中的工厂变量时,我注意到的一件事是它总是说“AllSchedulers:Count = 0” - 不确定是否因为我还没有实例化一个或者是否这是我问题的一部分。尝试从配置中提供GetScheduler() instanceName -

factory.GetScheduler("XxxDefaultQuartzScheduler")

也不起作用。

我错过了什么/做错了什么?请指教。

1 个答案:

答案 0 :(得分:9)

好的,找出了我自己的问题 - 属性quartz。 dataSource .useProperties应该是quartz。 jobStore .useProperties