我用下面的日志配置创建了一个简单的应用程序
<appenders>
<RollingRandomAccessFile name="SUMMARY_ALL" fileName="./logs/summary.log"
filePattern="logs/$${date:yyyy-MM}/summary-%d{yyyy-MM-dd-HH}-%i.log.gz" immediateFlush="false" append="false">
<PatternLayout>
<pattern>%d{ISO8601} [%t] %p %c %L - %m%n</pattern>
</PatternLayout>
<Policies>
<TimeBasedTriggeringPolicy interval="6"
modulate="true" />
<SizeBasedTriggeringPolicy size="10 MB" />
</Policies>
</RollingRandomAccessFile>
</appenders>
伐木者为:
<loggers>
<root level="DEBUG" includeLocation="false">
<AppenderRef ref="SUMMARY_ALL" />
</root>
</loggers>
当我运行它时,我总是让AsyncLogger处于等待状态。有人能帮忙吗。附加的是ThreadDump的快照。
发布于 2013-10-03 22:36:43
这个问题也被发布到log4j邮件列表中。讨论摘要:
AsyncLogger线程大部分时间都处于等待状态,要么等待新工作的到来,要么等待阻塞I/O调用返回。
这是预期的行为。只要事件被正确地记录下来,这就不是问题。
关于AsyncAppenders和AsyncLoggers之间区别的细节,可以在克里斯蒂安·格罗布迈尔的博客文章http://www.javacodegeeks.com/2013/07/log4j-2-performance-close-to-insane.html中找到。
https://stackoverflow.com/questions/19155581
复制相似问题