Log4j2:SMTPAppender不发送错误或致命级别的邮件

时间:2013-07-15 15:29:43

标签: java logging log4j2 smtpappender

我在log4j2中发现了SMTPAppender的一些问题。每当创建级别为errorfatal的日志事件时,如果没有,则在没有邮件发送且致命事件消失之前,该事件的级别为info。< / p>

这是我的log4j2配置文件(log4j2.xml)和一个小程序(LogTest.java)来重现问题:

<?xml version="1.0" encoding="UTF-8"?>
    <configuration status="warn">

        <!-- mail server configuration -->
        <properties>
            <property name="receipients">me@example.com</property>
            <property name="from">me@example.com</property>
            <property name="smtpHost">smtp.example.com</property>
            <property name="smtpPort">25</property>
            <property name="smtpProtocol">smtp</property>
            <property name="smtpUser">me</property>
            <property name="smtpPassword">secret</property>
        </properties>

    <appenders>

        <!-- appender to write all info events to stdout -->
        <Console name="Console" target="SYSTEM_OUT">
            <ThresholdFilter level="info" onMatch="NEUTRAL" onMismatch="DENY"/>
        </Console>

        <!-- appender to send mails (default: error and fatal events)-->
        <SMTP name="Mailer" suppressExceptions="false"
              subject="Error log" to="${receipients}" from="${from}"
              smtpHost="${smtpHost}" smtpPort="${smtpPort}"
              smtpProtocol="${smtpProtocol}" smtpUsername="${smtpUser}" 
              smtpPassword="${smtpPassword}" smtpDebug="false" bufferSize="2">
        </SMTP>
        <!-- appender to send mails asynchronously -->
        <Async name="AsyncMailer" > 
            <appender-ref ref="Mailer"/>
        </Async>

    </appenders>
    <loggers>

        <!-- logger to send mail on (at least) info level events -->
        <logger name="LogTest" level="info" additivity="true">
            <appender-ref ref="AsyncMailer"/>
        </logger>

        <!-- root logger to see what happens (info level and "above") -->
        <root level="info">
            <appender-ref ref="Console"/>
        </root>

    </loggers>
</configuration>

我使用这个小程序来重现问题(LogTest.java):

import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;

class LogTest
{
    private static Logger logger=LogManager.getLogger("LogTest");

    public void testlogger()
    {
        /* --> uncomment to enable first mail
        logger.info("test info 1");
        */
        logger.fatal("test fatal 1");

        /* --> uncomment to enable second mail
        logger.info("test info 2");
        */
        logger.fatal("test fatal 2");
    }

    public static void main(String[] args)
    {
        LogTest app=new LogTest();
        app.testlogger();
    }

}

如果取消注释两个标记位置,一切都按预期工作:发送两封邮件 - 每封邮件包含致命事件和先前的信息事件。此外,4个事件将打印到stdout:

test info 1
test fatal 1
test info 2
test fatal 2

现在,如果您只激活/取消注释第二个位置 - 第二个邮件(fatal2)按预期发送(再次使用先前的info2事件),但即使第一个致命事件打印到stdout,邮件也会被吃掉。输出如下:

test fatal 1
test info 2
test fatal 2

就我个人而言,似乎我遇到了错误并且错误配置了log4j2,或者它可能是一个错误。

提前感谢您的帮助。

*斯特

注意:

对于我使用从项目网站下载的log4j2-beta7的测试。 可以找到文档here

1 个答案:

答案 0 :(得分:3)

乍一看,这看起来像个臭虫。如果您删除LogTest记录器并配置这样的根记录器,它仍然会发生吗?

<root level="info">
    <appender-ref ref="Console"/>
    <appender-ref ref="AsyncMailer"/>
</root>

仅供参考,如果以后您需要在不同的appender上使用不同的日志级别,您可以实现这样的目标(不需要单独的记录器):

<root level="trace">
    <appender-ref ref="A" level="info" />
    <appender-ref ref="B" level="debug" />
</root>