e038d97f6df13878cedce6b9969095dcdf922142.svn-base 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  1. package com.xxl.job.admin.core.alarm.impl;
  2. import com.xxl.job.admin.core.alarm.JobAlarm;
  3. import com.xxl.job.admin.core.conf.XxlJobAdminConfig;
  4. import com.xxl.job.admin.core.model.XxlJobGroup;
  5. import com.xxl.job.admin.core.model.XxlJobInfo;
  6. import com.xxl.job.admin.core.model.XxlJobLog;
  7. import com.xxl.job.admin.core.util.I18nUtil;
  8. import com.xxl.job.core.biz.model.ReturnT;
  9. import org.slf4j.Logger;
  10. import org.slf4j.LoggerFactory;
  11. import org.springframework.mail.javamail.MimeMessageHelper;
  12. import org.springframework.stereotype.Component;
  13. import javax.mail.internet.MimeMessage;
  14. import java.text.MessageFormat;
  15. import java.util.Arrays;
  16. import java.util.HashSet;
  17. import java.util.Set;
  18. /**
  19. * job alarm by email
  20. *
  21. * @author xuxueli 2020-01-19
  22. */
  23. @Component
  24. public class EmailJobAlarm implements JobAlarm {
  25. private static Logger logger = LoggerFactory.getLogger(EmailJobAlarm.class);
  26. /**
  27. * fail alarm
  28. *
  29. * @param jobLog
  30. */
  31. public boolean doAlarm(XxlJobInfo info, XxlJobLog jobLog){
  32. boolean alarmResult = true;
  33. // send monitor email
  34. if (info!=null && info.getAlarmEmail()!=null && info.getAlarmEmail().trim().length()>0) {
  35. // alarmContent
  36. String alarmContent = "Alarm Job LogId=" + jobLog.getId();
  37. if (jobLog.getTriggerCode() != ReturnT.SUCCESS_CODE) {
  38. alarmContent += "<br>TriggerMsg=<br>" + jobLog.getTriggerMsg();
  39. }
  40. if (jobLog.getHandleCode()>0 && jobLog.getHandleCode() != ReturnT.SUCCESS_CODE) {
  41. alarmContent += "<br>HandleCode=" + jobLog.getHandleMsg();
  42. }
  43. // email info
  44. XxlJobGroup group = XxlJobAdminConfig.getAdminConfig().getXxlJobGroupDao().load(Integer.valueOf(info.getJobGroup()));
  45. String personal = I18nUtil.getString("admin_name_full");
  46. String title = I18nUtil.getString("jobconf_monitor");
  47. String content = MessageFormat.format(loadEmailJobAlarmTemplate(),
  48. group!=null?group.getTitle():"null",
  49. info.getId(),
  50. info.getJobDesc(),
  51. alarmContent);
  52. Set<String> emailSet = new HashSet<String>(Arrays.asList(info.getAlarmEmail().split(",")));
  53. for (String email: emailSet) {
  54. // make mail
  55. try {
  56. MimeMessage mimeMessage = XxlJobAdminConfig.getAdminConfig().getMailSender().createMimeMessage();
  57. MimeMessageHelper helper = new MimeMessageHelper(mimeMessage, true);
  58. helper.setFrom(XxlJobAdminConfig.getAdminConfig().getEmailUserName(), personal);
  59. helper.setTo(email);
  60. helper.setSubject(title);
  61. helper.setText(content, true);
  62. XxlJobAdminConfig.getAdminConfig().getMailSender().send(mimeMessage);
  63. } catch (Exception e) {
  64. logger.error(">>>>>>>>>>> xxl-job, job fail alarm email send error, JobLogId:{}", jobLog.getId(), e);
  65. alarmResult = false;
  66. }
  67. }
  68. }
  69. return alarmResult;
  70. }
  71. /**
  72. * load email job alarm template
  73. *
  74. * @return
  75. */
  76. private static final String loadEmailJobAlarmTemplate(){
  77. String mailBodyTemplate = "<h5>" + I18nUtil.getString("jobconf_monitor_detail") + ":</span>" +
  78. "<table border=\"1\" cellpadding=\"3\" style=\"border-collapse:collapse; width:80%;\" >\n" +
  79. " <thead style=\"font-weight: bold;color: #ffffff;background-color: #ff8c00;\" >" +
  80. " <tr>\n" +
  81. " <td width=\"20%\" >"+ I18nUtil.getString("jobinfo_field_jobgroup") +"</td>\n" +
  82. " <td width=\"10%\" >"+ I18nUtil.getString("jobinfo_field_id") +"</td>\n" +
  83. " <td width=\"20%\" >"+ I18nUtil.getString("jobinfo_field_jobdesc") +"</td>\n" +
  84. " <td width=\"10%\" >"+ I18nUtil.getString("jobconf_monitor_alarm_title") +"</td>\n" +
  85. " <td width=\"40%\" >"+ I18nUtil.getString("jobconf_monitor_alarm_content") +"</td>\n" +
  86. " </tr>\n" +
  87. " </thead>\n" +
  88. " <tbody>\n" +
  89. " <tr>\n" +
  90. " <td>{0}</td>\n" +
  91. " <td>{1}</td>\n" +
  92. " <td>{2}</td>\n" +
  93. " <td>"+ I18nUtil.getString("jobconf_monitor_alarm_type") +"</td>\n" +
  94. " <td>{3}</td>\n" +
  95. " </tr>\n" +
  96. " </tbody>\n" +
  97. "</table>";
  98. return mailBodyTemplate;
  99. }
  100. }