背景:
之前用 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