[英]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.