log4j 1.2 - 异步记录器内存使用限制设置

时间:2018-02-08 18:32:24

标签: java memory-management log4j

我想知道是否有办法限制异步记录器将使用的内存量。有一个缓冲区大小限制了日志元素在写入磁盘之前的数量,如下所示:

  <appender name="async" class="org.apache.log4j.AsyncAppender">
    <param name="BufferSize" value="1024"/>
    <appender-ref ref="ROLL"/>
  </appender>

但是,似乎没有任何方法可以限制log4j在决定阻塞和写出其队列之前使用的内存量。默认的缓冲区大小是128 LoggingEvents,但理论上每个LoggingEvent可以占用1 GB,这可以快速占用所有的perm gen空间。

整个队列的全局设置最好。我们宁愿不限制您可用于单个日志调用的内存量,但这可能是一个不错的最后手段。

非常感谢, 麦克

1 个答案:

答案 0 :(得分:1)

不,在Log4j 1.2中,缓冲区只是ArrayListsources非常简单明了。唯一可用的选项是blocking,它提供了在缓冲区已满时阻塞线程的选项。这将限制内存消耗,但也可能冻结应用程序,因为此时appender变为同步。

缓冲区实现在Log4j2中更改为Queue,并且policy可用于在缓冲区已满时设置appender行为。