因为logback中的SMTPAppender所使用的eventEvaluator默认是OnErrorEvaluator,只会针对error级别的日志发送邮件。如下是SMTPAppender的start()方法的逻辑:
java">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