我已经搜索了关于如何使用Mass Transit的Quartz集成(https://github.com/MassTransit/MassTransit-Quartz)的示例实现或博客文章的高低搜索。
目前我只需要查看代码库附带的单元测试,但我没有取得多大进展。
是否有任何示例或好的博客文章可以帮助我开始使用Mass Transit和Quartz Scheduling?
答案 0 :(得分:7)
此示例允许您在SQL数据库中保留MassTransit计划消息。开箱即用,MassTransit仅在内存中保留,而不进行一些配置更改。
首先,您需要对app / web.config文件进行细微更改,以包含以下2个块:
<configSections>
<section name="quartz" type="System.Configuration.NameValueSectionHandler, System, Version=1.0.5000.0,Culture=neutral, PublicKeyToken=b77a5c561934e089" />
<quartz>
<add key="quartz.scheduler.instanceName" value="MassTransit-Quartz" />
<add key="quartz.scheduler.instanceId" value="AUTO" />
<add key="quartz.threadPool.type" value="Quartz.Simpl.SimpleThreadPool, Quartz" />
<add key="quartz.threadPool.threadCount" value="4" />
<add key="quartz.threadPool.threadPriority" value="2" />
<add key="quartz.jobStore.misfireThreshold" value="60000" />
<add key="quartz.jobStore.type" value="Quartz.Impl.AdoJobStore.JobStoreTX, Quartz" />
<add key="quartz.jobStore.useProperties" value="false" />
<add key="quartz.jobStore.driverDelegateType" value="Quartz.Impl.AdoJobStore.SqlServerDelegate, Quartz" />
<add key="quartz.jobStore.clustered" value="true" />
<add key="quartz.jobStore.tablePrefix" value="QRTZ_" />
<add key="quartz.jobStore.dataSource" value="quartzDS" />
<add key="quartz.dataSource.quartzDS.connectionString" value="Server=(local);Database=Quartz;Integrated Security=SSPI" />
<add key="quartz.dataSource.quartzDS.provider" value="SqlServer-20" />
然后,在本地SQL中,创建一个名为“Quartz”的新数据库,下载quartz.net源并找到数据库脚本
“tables_sqlServer.sql”
在Quartz本地数据库上运行此命令以创建架构。 现在,您已准备好在数据库中保留预定消息,您需要从MassTransit Quartz集成库中订阅这两个消费者:
var scheduler = CreateScheduler();
sb.SubscribeConsumer(() => new ScheduleMessageConsumer(scheduler));
sb.SubscribeConsumer(() => new CancelScheduledMessageConsumer(scheduler));
调度程序是IScheduler的地方:
static IScheduler CreateScheduler()
{
ISchedulerFactory schedulerFactory = new StdSchedulerFactory();
return schedulerFactory.GetScheduler();
}
和sb是IServiceBus类型的servicebus。
最后,在您的代码调用中:
Bus.ScheduleMessage(SchedulePeriodInSecondsFromNow, MessageToSchedule);
拥有“MessageToSchedule”类型的消费者。 如果您打开数据库并查询QRTZ_TRIGGERS表,您将看到出现在那里和QRTZ_JOB_DETAILS中的作业。
希望这有帮助!