JobScheduler.cs 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. using wms.dto.request.hj;
  2. using wms.dto;
  3. using Quartz;
  4. using Quartz.Impl;
  5. using Quartz.Impl.Matchers;
  6. using Quartz.Impl.Triggers;
  7. namespace wms.api.Job
  8. {
  9. /// <summary>
  10. /// 任务调度器
  11. /// </summary>
  12. public class JobScheduler
  13. {
  14. public static IScheduler InitScheduler()
  15. {
  16. //创建调度器工厂
  17. ISchedulerFactory factory = new StdSchedulerFactory();
  18. //创建调度器对象
  19. IScheduler scheduler = factory.GetScheduler().Result;
  20. ////创建任务
  21. //IJobDetail job = JobBuilder.Create<PostJob>().Build();
  22. ////创建触发器
  23. //ITrigger trigger = TriggerBuilder.Create().WithIdentity("TimeTrigger", "TimeGroup").WithSimpleSchedule(p => p.WithIntervalInMinutes(1).RepeatForever()).Build();
  24. ////任务、触发器添至调度器对象
  25. //scheduler.ScheduleJob(job, trigger);
  26. //scheduler.Start();
  27. return scheduler;
  28. }
  29. public static void Start(string jobName, Type jobType, string timeCorn)
  30. {
  31. var sched = InitScheduler();
  32. var jobList = GetJobList(Const.JobGroupName).Result;
  33. var job = jobList.Where(p => jobName == p.JobName);
  34. if (job.Count() > 0)
  35. {
  36. //if (job.First().JobStatus == "Stop")
  37. {
  38. sched.DeleteJob(new JobKey(jobName, Const.JobGroupName));
  39. StartJob(jobName, jobType, timeCorn);
  40. }
  41. //else
  42. //{
  43. // ResumeAsync(jobName, Const.JobGroupName);
  44. //}
  45. }
  46. else
  47. {
  48. StartJob(jobName, jobType, timeCorn);
  49. }
  50. }
  51. public static async Task<List<SysJobDto>> GetJobList(string jobGroup)
  52. {
  53. var result = new List<SysJobDto>();
  54. try
  55. {
  56. var group = await InitScheduler().GetJobGroupNames();
  57. var currentlyExecutingJobs = await InitScheduler().GetCurrentlyExecutingJobs();
  58. var matcher = GroupMatcher<JobKey>.GroupEquals(jobGroup);
  59. var jobs = await InitScheduler().GetJobKeys(matcher);
  60. foreach (var item in jobs)
  61. {
  62. var triggers = await InitScheduler().GetTriggersOfJob(item);
  63. var state = await InitScheduler().GetTriggerState(triggers.First().Key);
  64. var job = InitScheduler().GetJobDetail(item).Result;
  65. result.Add(new SysJobDto()
  66. {
  67. JobName = job.Key.Name,
  68. JobDesc = job.Description,
  69. JobStatus = state.ToString(),
  70. JobGroup = job.Key.Group
  71. });
  72. }
  73. return result;
  74. }
  75. catch (Exception ex)
  76. { return result; }
  77. }
  78. public static void StartJob(string jobName, Type jobType, string timeCorn)
  79. {
  80. var scheduler = InitScheduler(); //获取对象
  81. //创建任务
  82. JobDetailImpl jobDetail = new JobDetailImpl();
  83. jobDetail.Name = jobName;
  84. jobDetail.JobType = jobType;
  85. jobDetail.Group = Const.JobGroupName;
  86. //创建触发器
  87. CronTriggerImpl trigger = new CronTriggerImpl();
  88. trigger.Name = jobName;
  89. trigger.Group = Const.TiggerGroupName;
  90. trigger.CronExpressionString = timeCorn;
  91. //任务、触发器添至调度器对象
  92. scheduler.ScheduleJob(jobDetail, trigger);
  93. if (!scheduler.IsShutdown)
  94. {
  95. scheduler.Start();
  96. }
  97. }
  98. }
  99. }