Log4j2 AsyncLogger始终是线程等待状态

时间:2013-10-03 09:30:02

标签: logging log4j log4j2

我使用以下日志配置创建了一个简单的应用程序

      <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的快照

enter image description here

1 个答案:

答案 0 :(得分:0)

此问题也发布在log4j邮件列表中。讨论摘要:

AsyncLogger线程大部分时间都处于等待状态,要么等待新工作到达,要么等待阻塞I / O调用返回。

这是预期的行为。只要正确记录事件,这不是问题。

有关AsyncAppenders和AsyncLoggers之间区别的详细信息,请参阅Christian Grobmeier的博文http://www.javacodegeeks.com/2013/07/log4j-2-performance-close-to-insane.html