我使用以下日志配置创建了一个简单的应用程序
<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的快照
答案 0 :(得分:0)
此问题也发布在log4j邮件列表中。讨论摘要:
AsyncLogger线程大部分时间都处于等待状态,要么等待新工作到达,要么等待阻塞I / O调用返回。
这是预期的行为。只要正确记录事件,这不是问题。
有关AsyncAppenders和AsyncLoggers之间区别的详细信息,请参阅Christian Grobmeier的博文http://www.javacodegeeks.com/2013/07/log4j-2-performance-close-to-insane.html。