配置与扩展
1、配置文件
通过文件可以配置多个本地化管理器,通过更换 default 的值即可实现无缝切换。配置文件如下:
- .Net Framework 下的 app.config 或 web.config 文件
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<configSections>
<sectionGroup name="fireasy">
<section name="taskSchedulers" type="Fireasy.Common.Tasks.Configuration.TaskScheduleConfigurationSectionHandler, Fireasy.Common" />
</sectionGroup>
</configSections>
<fireasy>
<taskSchedulers default="quartz">
<scheduler name="quartz" type="Fireasy.QuartzNet.TaskScheduler, Fireasy.QuartzNet" />
<scheduler name="demo" type="demo.TaskScheduler, demo" />
</taskSchedulers>
</fireasy>
</configuration>
- .Net Core 下的 appsettings.json 文件
{
"fireasy": {
"taskSchedulers": {
"default": "quartz",
"settings": {
"quartz": {
"type": "Fireasy.QuartzNet.TaskScheduler, Fireasy.QuartzNet"
},
"demo": {
"type": "demo.TaskScheduler, demo"
}
}
}
}
}
TaskSchedulerFactory
工厂类可以根据配置创建一个 ITaskScheduler
实例。如下所示:
[TestMethod]
public void TestCreateScheduler()
{
var scheduler1 = TaskSchedulerFactory.CreateScheduler();
Assert.IsNotNull(scheduler1); // QuartzNet
var scheduler2 = TaskSchedulerFactory.CreateScheduler("demo");
Assert.IsNotNull(scheduler2); // demo
}
在使用 IOC
的环境中,通过构造注入或属性注入得到的 ITaskScheduler
的实例对应的是指向 default 的配置项。
2、第三方适配
HangFire