326ef9ff8416e00193431563417de48d3d8ddcf8.svn-base 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232
  1. package com.xxl.job.admin.controller;
  2. import com.xxl.job.admin.core.exception.XxlJobException;
  3. import com.xxl.job.admin.core.model.XxlJobGroup;
  4. import com.xxl.job.admin.core.model.XxlJobInfo;
  5. import com.xxl.job.admin.core.model.XxlJobLog;
  6. import com.xxl.job.admin.core.scheduler.XxlJobScheduler;
  7. import com.xxl.job.admin.core.util.I18nUtil;
  8. import com.xxl.job.admin.dao.XxlJobGroupDao;
  9. import com.xxl.job.admin.dao.XxlJobInfoDao;
  10. import com.xxl.job.admin.dao.XxlJobLogDao;
  11. import com.xxl.job.core.biz.ExecutorBiz;
  12. import com.xxl.job.core.biz.model.KillParam;
  13. import com.xxl.job.core.biz.model.LogParam;
  14. import com.xxl.job.core.biz.model.LogResult;
  15. import com.xxl.job.core.biz.model.ReturnT;
  16. import com.xxl.job.core.util.DateUtil;
  17. import org.slf4j.Logger;
  18. import org.slf4j.LoggerFactory;
  19. import org.springframework.stereotype.Controller;
  20. import org.springframework.ui.Model;
  21. import org.springframework.web.bind.annotation.RequestMapping;
  22. import org.springframework.web.bind.annotation.RequestParam;
  23. import org.springframework.web.bind.annotation.ResponseBody;
  24. import javax.annotation.Resource;
  25. import javax.servlet.http.HttpServletRequest;
  26. import java.util.Date;
  27. import java.util.HashMap;
  28. import java.util.List;
  29. import java.util.Map;
  30. /**
  31. * index controller
  32. * @author xuxueli 2015-12-19 16:13:16
  33. */
  34. @Controller
  35. @RequestMapping("/joblog")
  36. public class JobLogController {
  37. private static Logger logger = LoggerFactory.getLogger(JobLogController.class);
  38. @Resource
  39. private XxlJobGroupDao xxlJobGroupDao;
  40. @Resource
  41. public XxlJobInfoDao xxlJobInfoDao;
  42. @Resource
  43. public XxlJobLogDao xxlJobLogDao;
  44. @RequestMapping
  45. public String index(HttpServletRequest request, Model model, @RequestParam(required = false, defaultValue = "0") Integer jobId) {
  46. // 执行器列表
  47. List<XxlJobGroup> jobGroupList_all = xxlJobGroupDao.findAll();
  48. // filter group
  49. List<XxlJobGroup> jobGroupList = JobInfoController.filterJobGroupByRole(request, jobGroupList_all);
  50. if (jobGroupList==null || jobGroupList.size()==0) {
  51. throw new XxlJobException(I18nUtil.getString("jobgroup_empty"));
  52. }
  53. model.addAttribute("JobGroupList", jobGroupList);
  54. // 任务
  55. if (jobId > 0) {
  56. XxlJobInfo jobInfo = xxlJobInfoDao.loadById(jobId);
  57. if (jobInfo == null) {
  58. throw new RuntimeException(I18nUtil.getString("jobinfo_field_id") + I18nUtil.getString("system_unvalid"));
  59. }
  60. model.addAttribute("jobInfo", jobInfo);
  61. // valid permission
  62. JobInfoController.validPermission(request, jobInfo.getJobGroup());
  63. }
  64. return "joblog/joblog.index";
  65. }
  66. @RequestMapping("/getJobsByGroup")
  67. @ResponseBody
  68. public ReturnT<List<XxlJobInfo>> getJobsByGroup(int jobGroup){
  69. List<XxlJobInfo> list = xxlJobInfoDao.getJobsByGroup(jobGroup);
  70. return new ReturnT<List<XxlJobInfo>>(list);
  71. }
  72. @RequestMapping("/pageList")
  73. @ResponseBody
  74. public Map<String, Object> pageList(HttpServletRequest request,
  75. @RequestParam(required = false, defaultValue = "0") int start,
  76. @RequestParam(required = false, defaultValue = "10") int length,
  77. int jobGroup, int jobId, int logStatus, String filterTime) {
  78. // valid permission
  79. JobInfoController.validPermission(request, jobGroup); // 仅管理员支持查询全部;普通用户仅支持查询有权限的 jobGroup
  80. // parse param
  81. Date triggerTimeStart = null;
  82. Date triggerTimeEnd = null;
  83. if (filterTime!=null && filterTime.trim().length()>0) {
  84. String[] temp = filterTime.split(" - ");
  85. if (temp.length == 2) {
  86. triggerTimeStart = DateUtil.parseDateTime(temp[0]);
  87. triggerTimeEnd = DateUtil.parseDateTime(temp[1]);
  88. }
  89. }
  90. // page query
  91. List<XxlJobLog> list = xxlJobLogDao.pageList(start, length, jobGroup, jobId, triggerTimeStart, triggerTimeEnd, logStatus);
  92. int list_count = xxlJobLogDao.pageListCount(start, length, jobGroup, jobId, triggerTimeStart, triggerTimeEnd, logStatus);
  93. // package result
  94. Map<String, Object> maps = new HashMap<String, Object>();
  95. maps.put("recordsTotal", list_count); // 总记录数
  96. maps.put("recordsFiltered", list_count); // 过滤后的总记录数
  97. maps.put("data", list); // 分页列表
  98. return maps;
  99. }
  100. @RequestMapping("/logDetailPage")
  101. public String logDetailPage(int id, Model model){
  102. // base check
  103. ReturnT<String> logStatue = ReturnT.SUCCESS;
  104. XxlJobLog jobLog = xxlJobLogDao.load(id);
  105. if (jobLog == null) {
  106. throw new RuntimeException(I18nUtil.getString("joblog_logid_unvalid"));
  107. }
  108. model.addAttribute("triggerCode", jobLog.getTriggerCode());
  109. model.addAttribute("handleCode", jobLog.getHandleCode());
  110. model.addAttribute("executorAddress", jobLog.getExecutorAddress());
  111. model.addAttribute("triggerTime", jobLog.getTriggerTime().getTime());
  112. model.addAttribute("logId", jobLog.getId());
  113. return "joblog/joblog.detail";
  114. }
  115. @RequestMapping("/logDetailCat")
  116. @ResponseBody
  117. public ReturnT<LogResult> logDetailCat(String executorAddress, long triggerTime, long logId, int fromLineNum){
  118. try {
  119. ExecutorBiz executorBiz = XxlJobScheduler.getExecutorBiz(executorAddress);
  120. ReturnT<LogResult> logResult = executorBiz.log(new LogParam(triggerTime, logId, fromLineNum));
  121. // is end
  122. if (logResult.getContent()!=null && logResult.getContent().getFromLineNum() > logResult.getContent().getToLineNum()) {
  123. XxlJobLog jobLog = xxlJobLogDao.load(logId);
  124. if (jobLog.getHandleCode() > 0) {
  125. logResult.getContent().setEnd(true);
  126. }
  127. }
  128. return logResult;
  129. } catch (Exception e) {
  130. logger.error(e.getMessage(), e);
  131. return new ReturnT<LogResult>(ReturnT.FAIL_CODE, e.getMessage());
  132. }
  133. }
  134. @RequestMapping("/logKill")
  135. @ResponseBody
  136. public ReturnT<String> logKill(int id){
  137. // base check
  138. XxlJobLog log = xxlJobLogDao.load(id);
  139. XxlJobInfo jobInfo = xxlJobInfoDao.loadById(log.getJobId());
  140. if (jobInfo==null) {
  141. return new ReturnT<String>(500, I18nUtil.getString("jobinfo_glue_jobid_unvalid"));
  142. }
  143. if (ReturnT.SUCCESS_CODE != log.getTriggerCode()) {
  144. return new ReturnT<String>(500, I18nUtil.getString("joblog_kill_log_limit"));
  145. }
  146. // request of kill
  147. ReturnT<String> runResult = null;
  148. try {
  149. ExecutorBiz executorBiz = XxlJobScheduler.getExecutorBiz(log.getExecutorAddress());
  150. runResult = executorBiz.kill(new KillParam(jobInfo.getId()));
  151. } catch (Exception e) {
  152. logger.error(e.getMessage(), e);
  153. runResult = new ReturnT<String>(500, e.getMessage());
  154. }
  155. if (ReturnT.SUCCESS_CODE == runResult.getCode()) {
  156. log.setHandleCode(ReturnT.FAIL_CODE);
  157. log.setHandleMsg( I18nUtil.getString("joblog_kill_log_byman")+":" + (runResult.getMsg()!=null?runResult.getMsg():""));
  158. log.setHandleTime(new Date());
  159. xxlJobLogDao.updateHandleInfo(log);
  160. return new ReturnT<String>(runResult.getMsg());
  161. } else {
  162. return new ReturnT<String>(500, runResult.getMsg());
  163. }
  164. }
  165. @RequestMapping("/clearLog")
  166. @ResponseBody
  167. public ReturnT<String> clearLog(int jobGroup, int jobId, int type){
  168. Date clearBeforeTime = null;
  169. int clearBeforeNum = 0;
  170. if (type == 1) {
  171. clearBeforeTime = DateUtil.addMonths(new Date(), -1); // 清理一个月之前日志数据
  172. } else if (type == 2) {
  173. clearBeforeTime = DateUtil.addMonths(new Date(), -3); // 清理三个月之前日志数据
  174. } else if (type == 3) {
  175. clearBeforeTime = DateUtil.addMonths(new Date(), -6); // 清理六个月之前日志数据
  176. } else if (type == 4) {
  177. clearBeforeTime = DateUtil.addYears(new Date(), -1); // 清理一年之前日志数据
  178. } else if (type == 5) {
  179. clearBeforeNum = 1000; // 清理一千条以前日志数据
  180. } else if (type == 6) {
  181. clearBeforeNum = 10000; // 清理一万条以前日志数据
  182. } else if (type == 7) {
  183. clearBeforeNum = 30000; // 清理三万条以前日志数据
  184. } else if (type == 8) {
  185. clearBeforeNum = 100000; // 清理十万条以前日志数据
  186. } else if (type == 9) {
  187. clearBeforeNum = 0; // 清理所有日志数据
  188. } else {
  189. return new ReturnT<String>(ReturnT.FAIL_CODE, I18nUtil.getString("joblog_clean_type_unvalid"));
  190. }
  191. List<Long> logIds = null;
  192. do {
  193. logIds = xxlJobLogDao.findClearLogIds(jobGroup, jobId, clearBeforeTime, clearBeforeNum, 1000);
  194. if (logIds!=null && logIds.size()>0) {
  195. xxlJobLogDao.clearLog(logIds);
  196. }
  197. } while (logIds!=null && logIds.size()>0);
  198. return ReturnT.SUCCESS;
  199. }
  200. }