|
@@ -6,6 +6,7 @@ import com.xxl.job.admin.core.model.XxlJobLog;
|
6
|
6
|
import com.xxl.job.admin.core.schedule.XxlJobDynamicScheduler;
|
7
|
7
|
import com.xxl.job.admin.core.util.MailUtil;
|
8
|
8
|
import com.xxl.job.core.biz.model.ReturnT;
|
|
9
|
+import org.apache.commons.collections.CollectionUtils;
|
9
|
10
|
import org.slf4j.Logger;
|
10
|
11
|
import org.slf4j.LoggerFactory;
|
11
|
12
|
|
|
@@ -35,33 +36,38 @@ public class JobFailMonitorHelper {
|
35
|
36
|
|
36
|
37
|
@Override
|
37
|
38
|
public void run() {
|
38
|
|
-
|
39
|
39
|
// monitor
|
40
|
40
|
while (!toStop) {
|
41
|
41
|
try {
|
42
|
|
- Integer jobLogId = JobFailMonitorHelper.instance.queue.take();
|
43
|
|
- if (jobLogId != null && jobLogId > 0) {
|
44
|
|
- XxlJobLog log = XxlJobDynamicScheduler.xxlJobLogDao.load(jobLogId);
|
45
|
|
- if (log!=null) {
|
46
|
|
- if (ReturnT.SUCCESS_CODE==log.getTriggerCode() && log.getHandleCode()==0) {
|
47
|
|
- // job running, wait + again monitor
|
48
|
|
- TimeUnit.SECONDS.sleep(10);
|
|
42
|
+ List<Integer> jobLogIdList = new ArrayList<Integer>();
|
|
43
|
+ int drainToNum = JobFailMonitorHelper.instance.queue.drainTo(jobLogIdList);
|
49
|
44
|
|
|
45
|
+ if (CollectionUtils.isNotEmpty(jobLogIdList)) {
|
|
46
|
+ for (Integer jobLogId : jobLogIdList) {
|
|
47
|
+ if (jobLogId==null || jobLogId==0) {
|
|
48
|
+ continue;
|
|
49
|
+ }
|
|
50
|
+ XxlJobLog log = XxlJobDynamicScheduler.xxlJobLogDao.load(jobLogId);
|
|
51
|
+ if (log == null) {
|
|
52
|
+ continue;
|
|
53
|
+ }
|
|
54
|
+ if (ReturnT.SUCCESS_CODE == log.getTriggerCode() && log.getHandleCode() == 0) {
|
50
|
55
|
JobFailMonitorHelper.monitor(jobLogId);
|
51
|
56
|
logger.info(">>>>>>>>>>> job monitor, job running, JobLogId:{}", jobLogId);
|
52
|
57
|
}
|
53
|
|
- if (ReturnT.SUCCESS_CODE==log.getTriggerCode() && ReturnT.SUCCESS_CODE==log.getHandleCode()) {
|
|
58
|
+ if (ReturnT.SUCCESS_CODE == log.getTriggerCode() && ReturnT.SUCCESS_CODE == log.getHandleCode()) {
|
54
|
59
|
// job success, pass
|
55
|
60
|
logger.info(">>>>>>>>>>> job monitor, job success, JobLogId:{}", jobLogId);
|
56
|
61
|
}
|
57
|
|
-
|
58
|
|
- if (ReturnT.FAIL_CODE == log.getTriggerCode()|| ReturnT.FAIL_CODE==log.getHandleCode()) {
|
|
62
|
+ if (ReturnT.FAIL_CODE == log.getTriggerCode() || ReturnT.FAIL_CODE == log.getHandleCode()) {
|
59
|
63
|
// job fail,
|
60
|
64
|
sendMonitorEmail(log);
|
61
|
65
|
logger.info(">>>>>>>>>>> job monitor, job fail, JobLogId:{}", jobLogId);
|
62
|
66
|
}
|
63
|
67
|
}
|
64
|
68
|
}
|
|
69
|
+
|
|
70
|
+ TimeUnit.SECONDS.sleep(10);
|
65
|
71
|
} catch (Exception e) {
|
66
|
72
|
logger.error("job monitor error:{}", e);
|
67
|
73
|
}
|