zoukankan      html  css  js  c++  java
  • 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
    
  • 相关阅读:
    [C++] split string by string
    工作三个月心得经验
    Ubuntu Command-Line: Enable Unlimited Scrolling in the Terminal
    What is the PPA and How to do with it ?
    WCF vs ASMX WebService
    The ShortCuts in the ADT (to be continued)
    when does the View.ondraw method get called
    Browsing Storage Resources with Server Explorer
    Get start with Android development
    C++ Frequently asking question
  • 原文地址:https://www.cnblogs.com/shuai7boy/p/Log4j.html
Copyright © 2011-2022 走看看