log4j 属性 DailyRollingFileAppender 不起作用

新手上路,请多包涵

我想要每日日志,日志文件附加了 yyyy-dd-mm 格式的日期。当我使用 DailyRollingFileAppender 时,不会创建新的日志文件。日志被写入同一个日志文件。此外,不考虑提供的日期模式。创建的日志文件是 LoggerFile.log。并且每个内容(即使是第二天)都写入此文件。

我正在使用 log4j-1.2.17 jar。我正在使用 Java 开发 Netbeans 7.3.1。

有没有人使用这个 JAR 并面临这样的问题。请帮忙!

这是我使用的属性文件的内容:

 # Root logger option
log4j.rootLogger=ERROR,FILE,stdout

# Define the file appender
log4j.appender.FILE=org.apache.log4j.DailyRollingFileAppender

log4j.appender.FILE.File=.//..//logs//LoggerFile.log

# Define the layout for file appender
log4j.appender.FILE.DatePattern='.'yyyy-MM-dd
log4j.appender.FILE.layout=org.apache.log4j.PatternLayout
log4j.appender.FILE.layout.conversionPattern=%d{yyyy-MM-dd HH:mm:ss.SSS zzz} %5p     %c{1}:%L - %m%n

log4j.appender.FILE.MaxFileSize=10MB

# Direct log messages to stdout
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target=System.out
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L -  %m%n`

原文由 Nitin Kundapur Bhat 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 1.4k
1 个回答

我对每日日志文件轮换有类似的要求..(虽然问题比较老,但认为答案会对其他人有所帮助)..

关键点:

  1. 首先,我们 可以避免使用 DailyRollingFileAppender 。为什么?已观察到 DailyRollingFileAppender 会出现同步问题和数据丢失。 log4j extras 伴侣包括新部署应考虑的备选方案,并在 org.apache.log4j.rolling.RollingFileAppender 的文档中进行了讨论。参考: Daily Rolling File Appender 文档

  2. Apache extras log4j,建议将 org.apache.log4j.rolling.RollingFileAppender基于时间的滚动策略 一起使用

  3. 可能会找到基于时间的日志轮换的 示例 配置。

希望这可以帮助。

原文由 Santosh Kumar Arjunan 发布,翻译遵循 CC BY-SA 3.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题