ScheduleUtils.java 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. package com.ruoyi.quartz.util;
  2. import org.quartz.CronScheduleBuilder;
  3. import org.quartz.CronTrigger;
  4. import org.quartz.Job;
  5. import org.quartz.JobBuilder;
  6. import org.quartz.JobDetail;
  7. import org.quartz.JobKey;
  8. import org.quartz.Scheduler;
  9. import org.quartz.SchedulerException;
  10. import org.quartz.TriggerBuilder;
  11. import org.quartz.TriggerKey;
  12. import com.ruoyi.common.constant.ScheduleConstants;
  13. import com.ruoyi.common.exception.job.TaskException;
  14. import com.ruoyi.common.exception.job.TaskException.Code;
  15. import com.ruoyi.quartz.domain.SysJob;
  16. /**
  17. * 定时任务工具类
  18. *
  19. * @author ruoyi
  20. */
  21. public class ScheduleUtils {
  22. /**
  23. * 得到quartz任务类
  24. *
  25. * @param sysJob 执行计划
  26. * @return 具体执行任务类
  27. */
  28. private static Class<? extends Job> getQuartzJobClass(SysJob sysJob) {
  29. boolean isConcurrent = "0".equals(sysJob.getConcurrent());
  30. return isConcurrent ? QuartzJobExecution.class : QuartzDisallowConcurrentExecution.class;
  31. }
  32. /**
  33. * 构建任务触发对象
  34. */
  35. public static TriggerKey getTriggerKey(Long jobId, String jobGroup) {
  36. return TriggerKey.triggerKey(ScheduleConstants.TASK_CLASS_NAME + jobId, jobGroup);
  37. }
  38. /**
  39. * 构建任务键对象
  40. */
  41. public static JobKey getJobKey(Long jobId, String jobGroup) {
  42. return JobKey.jobKey(ScheduleConstants.TASK_CLASS_NAME + jobId, jobGroup);
  43. }
  44. /**
  45. * 创建定时任务
  46. */
  47. public static void createScheduleJob(Scheduler scheduler, SysJob job) throws SchedulerException, TaskException {
  48. Class<? extends Job> jobClass = getQuartzJobClass(job);
  49. // 构建job信息
  50. Long jobId = job.getJobId();
  51. String jobGroup = job.getJobGroup();
  52. JobDetail jobDetail = JobBuilder.newJob(jobClass).withIdentity(getJobKey(jobId, jobGroup)).build();
  53. // 表达式调度构建器
  54. CronScheduleBuilder cronScheduleBuilder = CronScheduleBuilder.cronSchedule(job.getCronExpression());
  55. cronScheduleBuilder = handleCronScheduleMisfirePolicy(job, cronScheduleBuilder);
  56. // 按新的cronExpression表达式构建一个新的trigger
  57. CronTrigger trigger = TriggerBuilder.newTrigger().withIdentity(getTriggerKey(jobId, jobGroup))
  58. .withSchedule(cronScheduleBuilder).build();
  59. // 放入参数,运行时的方法可以获取
  60. jobDetail.getJobDataMap().put(ScheduleConstants.TASK_PROPERTIES, job);
  61. // 判断是否存在
  62. if (scheduler.checkExists(getJobKey(jobId, jobGroup))) {
  63. // 防止创建时存在数据问题 先移除,然后在执行创建操作
  64. scheduler.deleteJob(getJobKey(jobId, jobGroup));
  65. }
  66. scheduler.scheduleJob(jobDetail, trigger);
  67. // 暂停任务
  68. if (job.getStatus().equals(ScheduleConstants.Status.PAUSE.getValue())) {
  69. scheduler.pauseJob(ScheduleUtils.getJobKey(jobId, jobGroup));
  70. }
  71. }
  72. /**
  73. * 设置定时任务策略
  74. */
  75. public static CronScheduleBuilder handleCronScheduleMisfirePolicy(SysJob job, CronScheduleBuilder cb)
  76. throws TaskException {
  77. switch (job.getMisfirePolicy()) {
  78. case ScheduleConstants.MISFIRE_DEFAULT:
  79. return cb;
  80. case ScheduleConstants.MISFIRE_IGNORE_MISFIRES:
  81. return cb.withMisfireHandlingInstructionIgnoreMisfires();
  82. case ScheduleConstants.MISFIRE_FIRE_AND_PROCEED:
  83. return cb.withMisfireHandlingInstructionFireAndProceed();
  84. case ScheduleConstants.MISFIRE_DO_NOTHING:
  85. return cb.withMisfireHandlingInstructionDoNothing();
  86. default:
  87. throw new TaskException("The task misfire policy '" + job.getMisfirePolicy()
  88. + "' cannot be used in cron schedule tasks", Code.CONFIG_ERROR);
  89. }
  90. }
  91. }