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

问题描述 投票:1回答:1

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

  <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空间。

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

非常感谢,迈克

java memory-management log4j
1个回答
1
投票

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

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

© www.soinside.com 2019 - 2024. All rights reserved.