ソースを参照

失败告警策略扩展:默认提供邮件失败告警,可扩展短信等,扩展代码位置为 "JobFailMonitorHelper.failAlarm";

xuxueli 7 年 前
コミット
b7a2724f11
共有2 個のファイルを変更した11 個の追加4 個の削除を含む
  1. 1 0
      doc/XXL-JOB官方文档.md
  2. 10 4
      xxl-job-admin/src/main/java/com/xxl/job/admin/core/thread/JobFailMonitorHelper.java

+ 1 - 0
doc/XXL-JOB官方文档.md ファイルの表示

@@ -1021,6 +1021,7 @@ Tips: 历史版本(V1.3.x)目前已经Release至稳定版本, 进入维护阶段
1021 1021
 ### 6.20 版本 V1.9.0 特性[迭代中]
1022 1022
 - 1、新增任务运行模式 "GLUE模式(NodeJS) ",支持NodeJS脚本任务;
1023 1023
 - 2、修复任务监控线程被耗时任务阻塞的问题;
1024
+- 3、失败告警策略扩展:默认提供邮件失败告警,可扩展短信等,扩展代码位置为 "JobFailMonitorHelper.failAlarm";
1024 1025
 
1025 1026
 ### TODO LIST
1026 1027
 - 1、任务权限管理:执行器为粒度分配权限,核心操作校验权限;

+ 10 - 4
xxl-job-admin/src/main/java/com/xxl/job/admin/core/thread/JobFailMonitorHelper.java ファイルの表示

@@ -61,7 +61,7 @@ public class JobFailMonitorHelper {
61 61
 								}
62 62
 								if (ReturnT.FAIL_CODE == log.getTriggerCode() || ReturnT.FAIL_CODE == log.getHandleCode()) {
63 63
 									// job fail,
64
-									sendMonitorEmail(log);
64
+									failAlarm(log);
65 65
 									logger.info(">>>>>>>>>>> job monitor, job fail, JobLogId:{}", jobLogId);
66 66
 								}
67 67
 							}
@@ -81,7 +81,7 @@ public class JobFailMonitorHelper {
81 81
 						XxlJobLog log = XxlJobDynamicScheduler.xxlJobLogDao.load(jobLogId);
82 82
 						if (ReturnT.FAIL_CODE == log.getTriggerCode()|| ReturnT.FAIL_CODE==log.getHandleCode()) {
83 83
 							// job fail,
84
-							sendMonitorEmail(log);
84
+							failAlarm(log);
85 85
 							logger.info(">>>>>>>>>>> job monitor last, job fail, JobLogId:{}", jobLogId);
86 86
 						}
87 87
 					}
@@ -94,10 +94,13 @@ public class JobFailMonitorHelper {
94 94
 	}
95 95
 
96 96
 	/**
97
-	 * send monitor email
97
+	 * fail alarm
98
+	 *
98 99
 	 * @param jobLog
99 100
 	 */
100
-	private void sendMonitorEmail(XxlJobLog jobLog){
101
+	private void failAlarm(XxlJobLog jobLog){
102
+
103
+		// send monitor email
101 104
 		XxlJobInfo info = XxlJobDynamicScheduler.xxlJobInfoDao.loadById(jobLog.getJobId());
102 105
 		if (info!=null && info.getAlarmEmail()!=null && info.getAlarmEmail().trim().length()>0) {
103 106
 
@@ -109,6 +112,9 @@ public class JobFailMonitorHelper {
109 112
 				MailUtil.sendMail(email, title, content, false, null);
110 113
 			}
111 114
 		}
115
+
116
+		// TODO, custom alarm strategy, such as sms
117
+
112 118
 	}
113 119
 
114 120
 	public void toStop(){