SysJobServiceImpl.java 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246
  1. package com.ruoyi.quartz.service.impl;
  2. import cn.hutool.core.util.StrUtil;
  3. import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
  4. import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
  5. import com.ruoyi.common.constant.ScheduleConstants;
  6. import com.ruoyi.common.core.page.TableDataInfo;
  7. import com.ruoyi.common.exception.job.TaskException;
  8. import com.ruoyi.common.utils.PageUtils;
  9. import com.ruoyi.quartz.domain.SysJob;
  10. import com.ruoyi.quartz.mapper.SysJobMapper;
  11. import com.ruoyi.quartz.service.ISysJobService;
  12. import com.ruoyi.quartz.util.CronUtils;
  13. import com.ruoyi.quartz.util.ScheduleUtils;
  14. import org.quartz.JobDataMap;
  15. import org.quartz.JobKey;
  16. import org.quartz.Scheduler;
  17. import org.quartz.SchedulerException;
  18. import org.springframework.beans.factory.annotation.Autowired;
  19. import org.springframework.stereotype.Service;
  20. import org.springframework.transaction.annotation.Transactional;
  21. import javax.annotation.PostConstruct;
  22. import java.util.List;
  23. /**
  24. * 定时任务调度信息 服务层
  25. *
  26. * @author ruoyi
  27. */
  28. @Service
  29. public class SysJobServiceImpl extends ServiceImpl<SysJobMapper, SysJob> implements ISysJobService {
  30. @Autowired
  31. private Scheduler scheduler;
  32. /**
  33. * 项目启动时,初始化定时器 主要是防止手动修改数据库导致未同步到定时任务处理(注:不能手动修改数据库ID和任务组名,否则会导致脏数据)
  34. */
  35. @PostConstruct
  36. public void init() throws SchedulerException, TaskException {
  37. scheduler.clear();
  38. List<SysJob> jobList = list();
  39. for (SysJob job : jobList) {
  40. ScheduleUtils.createScheduleJob(scheduler, job);
  41. }
  42. }
  43. @Override
  44. public TableDataInfo<SysJob> selectPageJobList(SysJob job) {
  45. LambdaQueryWrapper<SysJob> lqw = new LambdaQueryWrapper<SysJob>()
  46. .like(StrUtil.isNotBlank(job.getJobName()), SysJob::getJobName, job.getJobName())
  47. .eq(StrUtil.isNotBlank(job.getJobGroup()), SysJob::getJobGroup, job.getJobGroup())
  48. .eq(StrUtil.isNotBlank(job.getStatus()), SysJob::getStatus, job.getStatus())
  49. .like(StrUtil.isNotBlank(job.getInvokeTarget()), SysJob::getInvokeTarget, job.getInvokeTarget());
  50. return PageUtils.buildDataInfo(page(PageUtils.buildPage(), lqw));
  51. }
  52. /**
  53. * 获取quartz调度器的计划任务列表
  54. *
  55. * @param job 调度信息
  56. * @return
  57. */
  58. @Override
  59. public List<SysJob> selectJobList(SysJob job) {
  60. return list(new LambdaQueryWrapper<SysJob>()
  61. .like(StrUtil.isNotBlank(job.getJobName()), SysJob::getJobName, job.getJobName())
  62. .eq(StrUtil.isNotBlank(job.getJobGroup()), SysJob::getJobGroup, job.getJobGroup())
  63. .eq(StrUtil.isNotBlank(job.getStatus()), SysJob::getStatus, job.getStatus())
  64. .like(StrUtil.isNotBlank(job.getInvokeTarget()), SysJob::getInvokeTarget, job.getInvokeTarget()));
  65. }
  66. /**
  67. * 通过调度任务ID查询调度信息
  68. *
  69. * @param jobId 调度任务ID
  70. * @return 调度任务对象信息
  71. */
  72. @Override
  73. public SysJob selectJobById(Long jobId) {
  74. return getById(jobId);
  75. }
  76. /**
  77. * 暂停任务
  78. *
  79. * @param job 调度信息
  80. */
  81. @Override
  82. @Transactional
  83. public int pauseJob(SysJob job) throws SchedulerException {
  84. Long jobId = job.getJobId();
  85. String jobGroup = job.getJobGroup();
  86. job.setStatus(ScheduleConstants.Status.PAUSE.getValue());
  87. int rows = baseMapper.updateById(job);
  88. if (rows > 0) {
  89. scheduler.pauseJob(ScheduleUtils.getJobKey(jobId, jobGroup));
  90. }
  91. return rows;
  92. }
  93. /**
  94. * 恢复任务
  95. *
  96. * @param job 调度信息
  97. */
  98. @Override
  99. @Transactional
  100. public int resumeJob(SysJob job) throws SchedulerException {
  101. Long jobId = job.getJobId();
  102. String jobGroup = job.getJobGroup();
  103. job.setStatus(ScheduleConstants.Status.NORMAL.getValue());
  104. int rows = baseMapper.updateById(job);
  105. if (rows > 0) {
  106. scheduler.resumeJob(ScheduleUtils.getJobKey(jobId, jobGroup));
  107. }
  108. return rows;
  109. }
  110. /**
  111. * 删除任务后,所对应的trigger也将被删除
  112. *
  113. * @param job 调度信息
  114. */
  115. @Override
  116. @Transactional
  117. public int deleteJob(SysJob job) throws SchedulerException {
  118. Long jobId = job.getJobId();
  119. String jobGroup = job.getJobGroup();
  120. int rows = baseMapper.deleteById(jobId);
  121. if (rows > 0) {
  122. scheduler.deleteJob(ScheduleUtils.getJobKey(jobId, jobGroup));
  123. }
  124. return rows;
  125. }
  126. /**
  127. * 批量删除调度信息
  128. *
  129. * @param jobIds 需要删除的任务ID
  130. * @return 结果
  131. */
  132. @Override
  133. @Transactional
  134. public void deleteJobByIds(Long[] jobIds) throws SchedulerException {
  135. for (Long jobId : jobIds) {
  136. SysJob job = getById(jobId);
  137. deleteJob(job);
  138. }
  139. }
  140. /**
  141. * 任务调度状态修改
  142. *
  143. * @param job 调度信息
  144. */
  145. @Override
  146. @Transactional
  147. public int changeStatus(SysJob job) throws SchedulerException {
  148. int rows = 0;
  149. String status = job.getStatus();
  150. if (ScheduleConstants.Status.NORMAL.getValue().equals(status)) {
  151. rows = resumeJob(job);
  152. } else if (ScheduleConstants.Status.PAUSE.getValue().equals(status)) {
  153. rows = pauseJob(job);
  154. }
  155. return rows;
  156. }
  157. /**
  158. * 立即运行任务
  159. *
  160. * @param job 调度信息
  161. */
  162. @Override
  163. @Transactional
  164. public void run(SysJob job) throws SchedulerException {
  165. Long jobId = job.getJobId();
  166. String jobGroup = job.getJobGroup();
  167. SysJob properties = selectJobById(job.getJobId());
  168. // 参数
  169. JobDataMap dataMap = new JobDataMap();
  170. dataMap.put(ScheduleConstants.TASK_PROPERTIES, properties);
  171. scheduler.triggerJob(ScheduleUtils.getJobKey(jobId, jobGroup), dataMap);
  172. }
  173. /**
  174. * 新增任务
  175. *
  176. * @param job 调度信息 调度信息
  177. */
  178. @Override
  179. @Transactional
  180. public int insertJob(SysJob job) throws SchedulerException, TaskException {
  181. job.setStatus(ScheduleConstants.Status.PAUSE.getValue());
  182. int rows = baseMapper.insert(job);
  183. if (rows > 0) {
  184. ScheduleUtils.createScheduleJob(scheduler, job);
  185. }
  186. return rows;
  187. }
  188. /**
  189. * 更新任务的时间表达式
  190. *
  191. * @param job 调度信息
  192. */
  193. @Override
  194. @Transactional
  195. public int updateJob(SysJob job) throws SchedulerException, TaskException {
  196. SysJob properties = selectJobById(job.getJobId());
  197. int rows = baseMapper.updateById(job);
  198. if (rows > 0) {
  199. updateSchedulerJob(job, properties.getJobGroup());
  200. }
  201. return rows;
  202. }
  203. /**
  204. * 更新任务
  205. *
  206. * @param job 任务对象
  207. * @param jobGroup 任务组名
  208. */
  209. public void updateSchedulerJob(SysJob job, String jobGroup) throws SchedulerException, TaskException {
  210. Long jobId = job.getJobId();
  211. // 判断是否存在
  212. JobKey jobKey = ScheduleUtils.getJobKey(jobId, jobGroup);
  213. if (scheduler.checkExists(jobKey)) {
  214. // 防止创建时存在数据问题 先移除,然后在执行创建操作
  215. scheduler.deleteJob(jobKey);
  216. }
  217. ScheduleUtils.createScheduleJob(scheduler, job);
  218. }
  219. /**
  220. * 校验cron表达式是否有效
  221. *
  222. * @param cronExpression 表达式
  223. * @return 结果
  224. */
  225. @Override
  226. public boolean checkCronExpressionIsValid(String cronExpression) {
  227. return CronUtils.isValid(cronExpression);
  228. }
  229. }