我想要每日日志,日志文件附加了 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 许可协议
我对每日日志文件轮换有类似的要求..(虽然问题比较老,但认为答案会对其他人有所帮助)..
关键点:
首先,我们 可以避免使用 DailyRollingFileAppender 。为什么?已观察到 DailyRollingFileAppender 会出现同步问题和数据丢失。 log4j extras 伴侣包括新部署应考虑的备选方案,并在 org.apache.log4j.rolling.RollingFileAppender 的文档中进行了讨论。参考: Daily Rolling File Appender 文档
Apache extras log4j,建议将 org.apache.log4j.rolling.RollingFileAppender 与 基于时间的滚动策略 一起使用
可能会找到基于时间的日志轮换的 示例 配置。
希望这可以帮助。