将大项目移植到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才能更新记录器配置。
答案 0 :(得分:3)
您使用的是什么版本的log4j2?我记得这是旧款测试版中的一个问题,但是它已经在beta5左右修复了......如果您使用的是最近的测试版,您是否可以提交错误报告?
作为一种变通方法,您可以使用%m%n
替换模式末尾的%m%ex%n
。