无法用log4j创建一个文件

问题描述:

目前我的代码是在控制台上打印日志,但它不是用日志创建文件。这是log4j.properties的代码:无法用log4j创建一个文件

log4j.rootLogger=file, stdout 

log4j.appender.file=org.apache.log4j.FileAppender 
log4j.appender.file.File=C:/logs/logging.log 
log4j.appender.file.ImmediateFlush=true 
log4j.appender.file.MaxFileSize=10MB 
log4j.appender.file.MaxBackupIndex=10 
log4j.appender.file.layout=org.apache.log4j.PatternLayout 
log4j.appender.file.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %L - %m%n 
log4j.appender.file.Append=true 
log4j.appender.file.Threshold=INFO 

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} %m%n 

这是在我的Spring应用程序的资源文件夹。 而这正是我使用它:

public void getPreviousDay() { 
     PropertyConfigurator.configure("log4j.properties"); 
     logger = Logger.getLogger(LocationScheduler.class); 
     logger.info("Test"); 
} 

有几个你需要使你的log4j.properties

  1. 首先log4j.rootLogger变化的指定日志级别,比附加器。所以在你的情况下,它必须是

    log4j.rootLogger= INFO, file, stdout

  2. 代替log4j.appender.file=org.apache.log4j.FileAppender使用log4j.appender.file=org.apache.log4j.RollingFileAppender为了得到一个翻转日志文件。

希望这会有所帮助。

编辑

看来你的程序将无法达到你的log4j.properties,原因是您正在使用的加载只需要的log4j.properties

如果你想要一个完全合格的路径的方法从类路径中使用加载log4j.properties以下版本:

PropertyConfigurator.configure(ClassLoader.getSystemResource("log4j.properties")); 
+0

我想你的建议和纠正我的代码,遗憾的是它没有工作:( –

+0

你确定你的log4j.properties可以加载吗? – Sanjeev

+0

请参阅编辑答案。它应该工作。 – Sanjeev