using Quartz; using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace IStation.Server { /// /// 单个任务辅助类 /// internal class DataDockingSingleJobHelper { private IScheduler _sched;//调度器 /// /// 数据对接配置 /// public Model.DataDockingProblem Problem { get; private set; } /// /// 开始任务 /// public async Task StartJob(Model.DataDockingProblem problem) { Problem = problem; var jobName = DataDockingJobNameHelper.GetJobName(problem); var jobGroupName = DataDockingJobNameHelper.GetJobGroupName(problem); var triggerName = DataDockingJobNameHelper.GetTriggerName(problem); // 1.创建scheduler的引用 var fac = new Quartz.Impl.StdSchedulerFactory(); _sched = await fac.GetScheduler(); //2.启动 scheduler await _sched.Start(); //3.创建任务 var job = JobBuilder.Create() .WithIdentity(jobName, jobGroupName) .Build(); job.JobDataMap.Put(DataDockingSingleJob.ProblemTagName, problem); //4.创建Trigger var trigger = TriggerBuilder.Create() .WithIdentity(triggerName, jobGroupName) .WithSimpleSchedule(x => x.WithIntervalInSeconds(problem.Interruption) .RepeatForever().WithMisfireHandlingInstructionNextWithRemainingCount()) .Build(); //5.加入调度管理器 await _sched.ScheduleJob(job, trigger); } /// /// 取消任务 /// public async Task CancelJob() { if (_sched == null) return; var triggerKey = new TriggerKey(DataDockingJobNameHelper.GetTriggerName(Problem), DataDockingJobNameHelper.GetJobGroupName(Problem)); if (await _sched.CheckExists(triggerKey)) { await _sched.UnscheduleJob(triggerKey); } } } }