tangxu
2023-04-21 473084031d410d95db66e81f4d1761f9a2d1b8e5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
using Quartz;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
 
namespace IStation.Server
{
    /// <summary>
    /// 单个任务辅助类
    /// </summary>
    internal class DataDockingSingleJobHelper
    {
        private IScheduler _sched;//调度器
 
        /// <summary>
        /// 数据对接配置
        /// </summary>
        public Model.DataDockingProblem Problem { get; private set; }
 
        /// <summary>
        /// 开始任务
        /// </summary>
        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<DataDockingSingleJob>()
             .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);
        }
 
        /// <summary>
        /// 取消任务
        /// </summary>
        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);
            }
        }
 
 
 
 
    }
}