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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值