12

日志记录会降低应用程序性能吗?以及如何限制在日志文件中打印显示标签日志?

例如。我的日志文件有以下日志

[2012-06-20 15:52:06,290] org.displaytag.tags.TableTag isFirstIteration 684 - [data] first iteration=true (row number=1)
[2012-06-20 15:52:06,290] org.displaytag.tags.TableTag isFirstIteration 684 - [data] first iteration=true (row number=1)
[2012-06-20 15:52:06,290] org.displaytag.tags.TableTag isFirstIteration 684 - [data] first iteration=true (row number=1)
[2012-06-20 15:52:06,290] org.displaytag.tags.TableTag isFirstIteration 684 - [data] first iteration=true (row number=1)

为什么以上在日志文件中?

log.properties 文件

# Log4j configuration file.
 log4j.rootCategory=DEBUG, A1
 # Available levels are DEBUG, INFO, WARN, ERROR, FATAL

 #
 # A1 is a ConsoleAppender 
 #

log4j.appender.A1 = org.apache.log4j.RollingFileAppender
log4j.appender.A1.File = C:/LogInfo/logfile.log
log4j.appender.A1.MaxFileSize = 100MB
log4j.appender.A1.MaxBackupIndex=50
log4j.appender.A1.layout = org.apache.log4j.PatternLayout
log4j.appender.A1.append = true
log4j.appender.A1.layout.ConversionPattern = [%d] %C %M %L - %m%n
log4j.appender.A1.Threshold = DEBUG

如何停止(org.displaytag.tags.TableTag)这些类型的日志打印在日志文件中

4

6 回答 6

11

日志记录会降低应用程序性能吗?

是的。它的作用取决于许多因素;见下文。

以及如何限制在日志文件中打印显示标签日志?

通过更改日志记录属性中的 ConversionPattern

为什么以上在日志文件中?

因为:

  1. 代码中的某处是使用该消息调用 Logger 方法(可能debug(String)),并且
  2. 您的日志记录属性将日志记录阈值设置为附加程序的调试。

要提高性能:

  1. 更改 ConversionPattern 以使用更便宜的日期/时间格式,并且(更重要的是)避免使用“C”、“F”、“L”和“M”,因为它们特别昂贵。
  2. 将日志记录阈值更改为 INFO 或 WARNING 或 ERROR 以减少日志记录量,
  3. Logger.debug(...)调用放在if检查是否启用调试日志记录的语句中。这节省了在不需要时组装日志消息的成本;请参阅在 log4j 中,在记录之前检查 isDebugEnabled 是否会提高性能?.
  4. 使用 log4j 版本 2 (log4j2),在采用格式和参数的日志记录方法上有重载。这些减少了在禁用级别进行日志记录时的开销。
  5. 还请查看 logback 和 log4j 2.0。

您还可以按照log4j 文档Logger中的描述在级别...限制日志记录。实际上,该文档回答了您提出的大部分问题,并且对日志记录性能和日志记录配置等主题有很多详细信息。

于 2012-06-20T10:55:39.713 回答
3

简短的回答:是的,它会降低应用程序的性能,因为它使用一些 CPU 周期和其他资源(内存等)。

另请参阅此问题:log4j 性能

于 2012-06-20T10:50:30.770 回答
1

日志记录可以占您 CPU 时间的 30% 或更多。就抖动而言,它与您的 GC 延迟一样大(并且更频繁)。

减少开销的一个简单方法是使用模式关闭记录每条消息的位置。在您的情况下,这是 %C %M 和 %L 因为它必须获取(整个堆栈的)堆栈跟踪才能获取此信息。

于 2012-06-20T10:55:11.850 回答
0

是的,他们这样做。这就是为什么您应该只记录错误或绝对必须记录的内容。您还可以在调试通道中记录有助于调试的信息,以免影响生产性能。

于 2012-06-20T10:50:29.810 回答
0

您可以像这样限制垃圾日志。将根记录器设置为 INFO,这样不必要的调试日志就不会出现并填满您的日志文件。

log4j.rootCategory=INFO, A1

如果您希望特定的类或包发出 DEBUG 日志,您可以这样做。

log4j.logger.org.hibernate.event.def.DefaultLoadEventListener=DEBUG,A1

以上将打印日志文件中 DefaultLoadEventListener 类的 DEBUG 级别日志以及其他 INFO 级别日志。

于 2012-06-20T10:56:09.820 回答
0

怎么样?

log4j.category.org.displaytag.tags.TableTag=ERROR, A1
于 2012-06-20T10:59:11.727 回答