Log4j不寫入日志文件排錯記錄


背景:

之前用 log4j一直設置的輸出到控制台。今天由於job任務出現了異常,因為是異步的,沒辦法在控制台看錯誤信息了,於是乎決定把日志打印到文件里面。然后就找了篇博客配置了下。但是配置完后,怎么也看不到有內容輸入到日志文件,而且還不報錯,很奇怪,於是排查了下。

解決思路:

1.首先新建立了一個控制台項目對博客案例進行了獨立測試,證明是好使的。

2.根據差異排查,只有引入的jar包不同,於是開始排查jar包。

  2.1將異常項目的所有jar包引入到獨立測試項目。

  2.2將jar包分批進行排查,逐漸縮小范圍,直到出現異常為止。這樣就找出了異常包。

  2.3然后看下異常包具體作用,為啥引入了log4j就不好使了。 如果在項目中沒啥作用的化,在項目中排除異常包就可以了。

我的異常包是:hhadoop-mapreduce-client-jobclient.jar包和hadoop-mapreduce-client-jobclient-tests.jar,然后去掉就OK了。

log4j.properties配置文件:

log4j.rootCategory=DEBUG, CONSOLE,LOGFILE

log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender
log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout
log4j.appender.CONSOLE.layout.ConversionPattern=-%p-%d{yyyy/MM/dd HH:mm:ss,SSS}-%l-%L-%m%n

log4j.appender.LOGFILE=org.apache.log4j.FileAppender
log4j.appender.logFile.Threshold=DEBUG
log4j.appender.logFile.ImmediateFlush=true
log4j.appender.LOGFILE.Append=true
log4j.appender.LOGFILE.File=logs/mylog.log
log4j.appender.LOGFILE.layout=org.apache.log4j.PatternLayout
log4j.appender.LOGFILE.layout.ConversionPattern=-%p-%d{yyyy/MM/dd HH:mm:ss,SSS}-%l-%L-%m%n


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM