2017-03-07 61 views
0

目前我的代碼是在控制檯上打印日誌,但它不是用日誌創建文件。這是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"); 
} 

回答

0

有幾個你需要使你的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