Spring Boot 中logback无法对warn警告日志发送邮件
因为logback中的SMTPAppender所使用的eventEvaluator默认是OnErrorEvaluator,只会针对error级别的日志发送邮件。如下是SMTPAppender的start()方法的逻辑:
public void start() {
if (eventEvaluator == null) {
OnErrorEvaluator onError = new OnErrorEvaluator();
onError.setContext(getContext());
onError.setName("onError");
onError.start();
this.eventEvaluator = onError;
}
super.start();
}
因此为了能对warn日志发送邮件,除了需要正确配置SMTPAppender的filter外(使之能接受warn日志),还需要对SMTPAppender配置evaluator属性进行配置,使之允许对warn日志发送邮件,例如:
<appender name="MAIL_WARN" class="ch.qos.logback.classic.net.SMTPAppender">
<evaluator class="ch.qos.logback.classic.boolex.JaninoEventEvaluator">
<expression>return level >= WARN;</expression>
</evaluator>
<filter class="ch.qos.logback.classic.filter.ThresholdFilter">
<level>WARN</level>
</filter>
</appender>
参考资料:
https://stackoverflow.com/questions/24739509/logback-fire-mail-for-warnings