繁体   English   中英

使用 log4j 清除文件?

[英]using log4j for clearing a file?

我使用 log4j 写入具有以下属性文件的文件:

log4j.rootLogger=DEBUG, FA

#File Appender
log4j.appender.FA=org.apache.log4j.FileAppender
log4j.appender.FA.File=temp.ppr
log4j.appender.FA.layout=org.apache.log4j.PatternLayout
log4j.appender.FA.layout.ConversionPattern= %m%n

我的问题是,在我的程序的每次运行中,我想清除文件“temp.ppr”,然后用 lo4j 有效地写入它? 还是您推荐其他解决方案?

谢谢

您是否尝试过append FileAppender上的append属性设置为false

log4j.appender.FA.append=false

你可以这样做:

log4j.appender.FA=org.apache.log4j.RollingFileAppender
log4j.appender.FA.MaxBackupIndex=1

然后在应用程序的启动代码中:

((RollingFileAppender)Logger.getRootLogger().getAppender("FA")).rollOver()

这样,对于程序的每次运行,现有日志都会移动到“temp.ppr.1”,而“temp.ppr”会从新开始。 这样,您也始终拥有上次运行的日志。

我建议作为您的构建工具(Apache Ant 或 Maven)的一部分来处理清除您不想要的文件。 或者,如果您想保留备份,您可以使用RollingFileAppender

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM