记录异常的问题

时间:2013-07-20 13:54:36

标签: java logging configuration log4j log4j2

将大项目移植到log4j2之后,我注意到异常的记录不起作用。这样的代码

logger.error("Error occurred", e);

不记录异常调用堆栈。上述行的日志仅包含:

21/07/2013 15:51:34 ERROR [MyTask-1] [MyManager] Error occurred

请帮助配置记录器。

更新: 我的log4j2.xml通常看起来像这样(我删除了其余的appender和logger):

<?xml version="1.0" encoding="UTF-8"?>
<configuration name="server" monitorInterval="30">
<appenders>
    <!-- ################# All Appender ############################### -->
    <RollingFile name="AllAppender" fileName="${sys:workspace}/logs/all.log" filePattern="${sys:workspace}/archive/logs/all_%d{yyyy-MM-dd_HH}.log">
        <PatternLayout>
            <pattern>%d{dd/MM/yyyy HH:mm:ss} %-5p [%t] [%c{1}] %m%n</pattern>
        </PatternLayout>
        <Policies>
            <OnStartupTriggeringPolicy />
            <TimeBasedTriggeringPolicy interval="1" modulate="true"/>
            <SizeBasedTriggeringPolicy size="10 MB"/>
        </Policies>
        <DefaultRolloverStrategy max="50"/>
    </RollingFile>

</appenders>

<loggers>
    <!-- #################################################################################################### -->
    <!-- ################################### Loggers definitions ############################################ -->
    <!-- #################################################################################################### -->

    <logger name="com" level="debug">
        <appender-ref ref="AllAppender" />
    </logger>

    <root level="debug">
        <appender-ref ref="AllAppender"/>
    </root>

</loggers>

顺便说一句,monitorInterval对我不起作用。我必须重新启动tomcat才能更新记录器配置。

1 个答案:

答案 0 :(得分:3)

您使用的是什么版本的log4j2?我记得这是旧款测试版中的一个问题,但是它已经在beta5左右修复了......如果您使用的是最近的测试版,您是否可以提交错误报告?

作为一种变通方法,您可以使用%m%n替换模式末尾的%m%ex%n