JobInfoController.java 8.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262
  1. package com.xxl.job.controller;
  2. import java.util.HashMap;
  3. import java.util.List;
  4. import java.util.Map;
  5. import javax.annotation.Resource;
  6. import org.apache.commons.lang.StringUtils;
  7. import org.quartz.CronExpression;
  8. import org.quartz.SchedulerException;
  9. import org.springframework.stereotype.Controller;
  10. import org.springframework.ui.Model;
  11. import org.springframework.web.bind.annotation.RequestMapping;
  12. import org.springframework.web.bind.annotation.RequestParam;
  13. import org.springframework.web.bind.annotation.ResponseBody;
  14. import com.xxl.job.client.handler.HandlerRepository;
  15. import com.xxl.job.client.util.JacksonUtil;
  16. import com.xxl.job.core.constant.Constants.JobGroupEnum;
  17. import com.xxl.job.core.model.ReturnT;
  18. import com.xxl.job.core.model.XxlJobInfo;
  19. import com.xxl.job.core.util.DynamicSchedulerUtil;
  20. import com.xxl.job.dao.IXxlJobInfoDao;
  21. import com.xxl.job.service.job.RemoteHttpJobBean;
  22. /**
  23. * index controller
  24. * @author xuxueli 2015-12-19 16:13:16
  25. */
  26. @Controller
  27. @RequestMapping("/jobinfo")
  28. public class JobInfoController {
  29. @Resource
  30. private IXxlJobInfoDao xxlJobInfoDao;
  31. @RequestMapping
  32. public String index(Model model) {
  33. model.addAttribute("JobGroupList", JobGroupEnum.values()); // 任务组列表
  34. return "jobinfo/index";
  35. }
  36. @RequestMapping("/pageList")
  37. @ResponseBody
  38. public Map<String, Object> pageList(@RequestParam(required = false, defaultValue = "0") int start,
  39. @RequestParam(required = false, defaultValue = "10") int length,
  40. String jobGroup, String jobName, String filterTime) {
  41. // page list
  42. List<XxlJobInfo> list = xxlJobInfoDao.pageList(start, length, jobGroup, jobName);
  43. int list_count = xxlJobInfoDao.pageListCount(start, length, jobGroup, jobName);
  44. // fill job info
  45. if (list!=null && list.size()>0) {
  46. for (XxlJobInfo jobInfo : list) {
  47. DynamicSchedulerUtil.fillJobInfo(jobInfo);
  48. }
  49. }
  50. // package result
  51. Map<String, Object> maps = new HashMap<String, Object>();
  52. maps.put("recordsTotal", list_count); // 总记录数
  53. maps.put("recordsFiltered", list_count); // 过滤后的总记录数
  54. maps.put("data", list); // 分页列表
  55. return maps;
  56. }
  57. @RequestMapping("/add")
  58. @ResponseBody
  59. public ReturnT<String> add(String jobGroup, String jobName, String jobCron, String jobDesc,
  60. String handler_address, String handler_name, String handler_params,
  61. String author, String alarmEmail, int alarmThreshold, int glueSwitch) {
  62. // valid
  63. if (JobGroupEnum.match(jobGroup) == null) {
  64. return new ReturnT<String>(500, "请选择“任务组”");
  65. }
  66. if (StringUtils.isBlank(jobName)) {
  67. return new ReturnT<String>(500, "请输入“任务名”");
  68. }
  69. if (!CronExpression.isValidExpression(jobCron)) {
  70. return new ReturnT<String>(500, "“corn”不合法");
  71. }
  72. if (StringUtils.isBlank(jobDesc)) {
  73. return new ReturnT<String>(500, "请输入“任务描述”");
  74. }
  75. if (StringUtils.isBlank(handler_address)) {
  76. return new ReturnT<String>(500, "请输入“机器地址”");
  77. }
  78. if (glueSwitch==0 && StringUtils.isBlank(handler_name)) {
  79. return new ReturnT<String>(500, "请输入“执行器”");
  80. }
  81. if (StringUtils.isBlank(author)) {
  82. return new ReturnT<String>(500, "请输入“负责人”");
  83. }
  84. if (StringUtils.isBlank(alarmEmail)) {
  85. return new ReturnT<String>(500, "请输入“报警邮件”");
  86. }
  87. if (alarmThreshold < 0) {
  88. alarmThreshold = 0;
  89. }
  90. try {
  91. if (DynamicSchedulerUtil.checkExists(jobName, jobGroup)) {
  92. return new ReturnT<String>(500, "此任务已存在,请更换任务组或任务名");
  93. }
  94. } catch (SchedulerException e1) {
  95. e1.printStackTrace();
  96. return new ReturnT<String>(500, "此任务已存在,请更换任务组或任务名");
  97. }
  98. // parse jobDataMap
  99. HashMap<String, String> jobDataMap = new HashMap<String, String>();
  100. jobDataMap.put(HandlerRepository.HANDLER_ADDRESS, handler_address);
  101. jobDataMap.put(HandlerRepository.HANDLER_NAME, handler_name);
  102. jobDataMap.put(HandlerRepository.HANDLER_PARAMS, handler_params);
  103. // Backup to the database
  104. XxlJobInfo jobInfo = new XxlJobInfo();
  105. jobInfo.setJobGroup(jobGroup);
  106. jobInfo.setJobName(jobName);
  107. jobInfo.setJobCron(jobCron);
  108. jobInfo.setJobDesc(jobDesc);
  109. jobInfo.setJobClass(RemoteHttpJobBean.class.getName());
  110. jobInfo.setJobData(JacksonUtil.writeValueAsString(jobDataMap));
  111. jobInfo.setAuthor(author);
  112. jobInfo.setAlarmEmail(alarmEmail);
  113. jobInfo.setAlarmThreshold(alarmThreshold);
  114. jobInfo.setGlueSwitch(glueSwitch);
  115. jobInfo.setGlueSource(null);
  116. jobInfo.setGlueRemark(null);
  117. xxlJobInfoDao.save(jobInfo);
  118. try {
  119. // add job 2 quartz
  120. boolean result = DynamicSchedulerUtil.addJob(jobInfo);
  121. if (result) {
  122. return ReturnT.SUCCESS;
  123. } else {
  124. xxlJobInfoDao.delete(jobGroup, jobName);
  125. return new ReturnT<String>(500, "新增任务失败");
  126. }
  127. } catch (SchedulerException e) {
  128. e.printStackTrace();
  129. }
  130. return ReturnT.FAIL;
  131. }
  132. @RequestMapping("/reschedule")
  133. @ResponseBody
  134. public ReturnT<String> reschedule(String jobGroup, String jobName, String jobCron, String jobDesc,
  135. String handler_address, String handler_name, String handler_params,
  136. String author, String alarmEmail, int alarmThreshold, int glueSwitch) {
  137. // valid
  138. if (JobGroupEnum.match(jobGroup) == null) {
  139. return new ReturnT<String>(500, "请选择“任务组”");
  140. }
  141. if (StringUtils.isBlank(jobName)) {
  142. return new ReturnT<String>(500, "请输入“任务名”");
  143. }
  144. if (!CronExpression.isValidExpression(jobCron)) {
  145. return new ReturnT<String>(500, "“corn”不合法");
  146. }
  147. if (StringUtils.isBlank(jobDesc)) {
  148. return new ReturnT<String>(500, "请输入“任务描述”");
  149. }
  150. if (StringUtils.isBlank(handler_address)) {
  151. return new ReturnT<String>(500, "请输入“机器地址”");
  152. }
  153. if (glueSwitch==0 && StringUtils.isBlank(handler_name)) {
  154. return new ReturnT<String>(500, "请输入“执行器”");
  155. }
  156. if (StringUtils.isBlank(author)) {
  157. return new ReturnT<String>(500, "请输入“负责人”");
  158. }
  159. if (StringUtils.isBlank(alarmEmail)) {
  160. return new ReturnT<String>(500, "请输入“报警邮件”");
  161. }
  162. if (alarmThreshold < 0) {
  163. alarmThreshold = 0;
  164. }
  165. // parse jobDataMap
  166. HashMap<String, String> jobDataMap = new HashMap<String, String>();
  167. jobDataMap.put(HandlerRepository.HANDLER_ADDRESS, handler_address);
  168. jobDataMap.put(HandlerRepository.HANDLER_NAME, handler_name);
  169. jobDataMap.put(HandlerRepository.HANDLER_PARAMS, handler_params);
  170. XxlJobInfo jobInfo = xxlJobInfoDao.load(jobGroup, jobName);
  171. jobInfo.setJobCron(jobCron);
  172. jobInfo.setJobDesc(jobDesc);
  173. jobInfo.setJobData(JacksonUtil.writeValueAsString(jobDataMap));
  174. jobInfo.setAuthor(author);
  175. jobInfo.setAlarmEmail(alarmEmail);
  176. jobInfo.setAlarmThreshold(alarmThreshold);
  177. jobInfo.setGlueSwitch(glueSwitch);
  178. try {
  179. // fresh quartz
  180. DynamicSchedulerUtil.rescheduleJob(jobInfo);
  181. // fresh db
  182. xxlJobInfoDao.update(jobInfo);
  183. return ReturnT.SUCCESS;
  184. } catch (SchedulerException e) {
  185. e.printStackTrace();
  186. }
  187. return ReturnT.FAIL;
  188. }
  189. @RequestMapping("/remove")
  190. @ResponseBody
  191. public ReturnT<String> remove(String jobGroup, String jobName) {
  192. try {
  193. DynamicSchedulerUtil.removeJob(jobName, jobGroup);
  194. xxlJobInfoDao.delete(jobGroup, jobName);
  195. return ReturnT.SUCCESS;
  196. } catch (SchedulerException e) {
  197. e.printStackTrace();
  198. }
  199. return ReturnT.FAIL;
  200. }
  201. @RequestMapping("/pause")
  202. @ResponseBody
  203. public ReturnT<String> pause(String jobGroup, String jobName) {
  204. try {
  205. DynamicSchedulerUtil.pauseJob(jobName, jobGroup); // jobStatus do not store
  206. return ReturnT.SUCCESS;
  207. } catch (SchedulerException e) {
  208. e.printStackTrace();
  209. return ReturnT.FAIL;
  210. }
  211. }
  212. @RequestMapping("/resume")
  213. @ResponseBody
  214. public ReturnT<String> resume(String jobGroup, String jobName) {
  215. try {
  216. DynamicSchedulerUtil.resumeJob(jobName, jobGroup);
  217. return ReturnT.SUCCESS;
  218. } catch (SchedulerException e) {
  219. e.printStackTrace();
  220. return ReturnT.FAIL;
  221. }
  222. }
  223. @RequestMapping("/trigger")
  224. @ResponseBody
  225. public ReturnT<String> triggerJob(String jobGroup, String jobName) {
  226. try {
  227. DynamicSchedulerUtil.triggerJob(jobName, jobGroup);
  228. return ReturnT.SUCCESS;
  229. } catch (SchedulerException e) {
  230. e.printStackTrace();
  231. return ReturnT.FAIL;
  232. }
  233. }
  234. }