zoukankan      html  css  js  c++  java
  • 日志框架SLF4J和log4j以及logback的联系和区别

    SLF4J它只是一个接口,并不是一个具体的可以直接单独使用的日志框架,所以最终日志的格式、记录级别、输出方式等都要通过接口绑定的具体的日志系统来实现,这些具体的日志系统就有log4j,logback,java.util.logging等

    每个Logger都被了一个日志级别(log level),用来控制日志信息的输出。日志级别从高到低分为:
    A:off         最高等级,用于关闭所有日志记录。
    B:fatal       指出每个严重的错误事件将会导致应用程序的退出。
    C:error      指出虽然发生错误事件,但仍然不影响系统的继续运行。
    D:warm     表明会出现潜在的错误情形。
    E:info         一般和在粗粒度级别上,强调应用程序的运行全程。
    F:debug     一般用于细粒度级别上,对调试应用程序非常有帮助。
    G:all           最低等级,用于打开所有日志记录。

    但是Log4j官方建议实际实用的话,Log4j建议只使用四个级别,优先级从高到低分别是 ERROR、WARN、INFO、DEBUG
    假如rootLogger定义的是DEBUG 那所有的报错信息都会输出

    Log4j rootLogger配置

    log4j.rootLogger = [ level ] , appenderName, appenderName, …      #指代 把指定级别的日志信息输出到指定的一个或者多个位置

     这里我们把INFO层级以及以上的信息输出到Console和File;

    Log4j appender输出类型配置

    Log4j官方的appender给出了一下几种实现:

    org.apache.log4j.ConsoleAppender(控制台), 
    org.apache.log4j.FileAppender(文件), 
    org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件), 
    org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件), 
    org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)
    实际开发我们使用第1,第3和第4种实现;
    假如日志数据量不是很大,我们可以用DailyRollingFileAppender 每天产生一个日志,方便查看;
    假如日志数据量很大,我们一般用RollingFileAppender,固定尺寸的日志,假如超过了 就产生一个新的文件;

    我们这里给出一些实例;

    log4j.rootLogger=DEBUG, Console ,File ,DailyRollingFile ,RollingFile

    #Console
    log4j.appender.Console=org.apache.log4j.ConsoleAppender
    log4j.appender.Console.layout=org.apache.log4j.PatternLayout
    log4j.appender.Console.layout.ConversionPattern=%d{yyyy-M-d HH:mm:ss} %p %x [%c] -%m%n

    #File
    log4j.appender.File = org.apache.log4j.FileAppender
    log4j.appender.File.File = C://log2.log
    log4j.appender.File.layout = org.apache.log4j.PatternLayout
    log4j.appender.File.layout.ConversionPattern =%d{yyyy-M-d HH:mm:ss} %p %x [%c] -%m%n

    #DailyRollingFile
    log4j.appender.DailyRollingFile = org.apache.log4j.DailyRollingFileAppender
    log4j.appender.DailyRollingFile.File = C://log3.log
    log4j.appender.DailyRollingFile.layout = org.apache.log4j.PatternLayout
    log4j.appender.DailyRollingFile.layout.ConversionPattern =%d{yyyy-M-d HH:mm:ss} %p %x [%c] -%m%n

    #RollingFile
    log4j.appender.RollingFile = org.apache.log4j.RollingFileAppender
    log4j.appender.RollingFile.File = C://log4.log
    log4j.appender.RollingFile.MaxFileSize=1KB
    log4j.appender.RollingFile.MaxBackupIndex=3
    log4j.appender.RollingFile.layout = org.apache.log4j.PatternLayout
    log4j.appender.RollingFile.layout.ConversionPattern =%d{yyyy-M-d HH:mm:ss} %p %x [%c] -%m%n

    log4j layout日志信息格式

    org.apache.log4j.HTMLLayout(以HTML表格形式布局),  
    org.apache.log4j.PatternLayout(可以灵活地指定布局模式),           #实际开发使用
    org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串),  
    org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)

    Log4j Threshold属性指定输出等级

    有时候我们需要把一些报错ERROR日志单独存到指定文件 ,这时候,Threshold属性就派上用场了;

    Threshold属性可以指定日志level
    Log4j根据日志信息的重要程度,分OFF、FATAL、ERROR、WARN、INFO、DEBUG、ALL
    比如我们指定某个appender的Threshold为WARN,那这个appender输出的日志信息就是WARN级别以及WARN以上的级别;
    假如我们指定的是ERROR,那这个就输出ERROR或者FATAL日志信息;
    当然这里有个提前 rootLogger里配置的level比如小于Threshold层级 否则无效 还是按照总的rootLogger里的level来输出,一般我们实际实用的话 rootLogger里配置DEBUG,然后某个文件专门存储ERRO日志,就配置下Threshold为ERROR,这个就是我们的最佳实践,不要乱七八糟瞎配置;
    我们给下参考配置:

    log4j.rootLogger=DEBUG, Console ,DFile ,EFILE
       
    #Console  
    log4j.appender.Console=org.apache.log4j.ConsoleAppender  
    log4j.appender.Console.layout=org.apache.log4j.TTCCLayout  
    
    #DEBUGFile
    log4j.appender.DFile = org.apache.log4j.FileAppender
    log4j.appender.DFile.File = C://DEBUG.log
    log4j.appender.DFile.layout = org.apache.log4j.PatternLayout
    log4j.appender.DFile.layout.ConversionPattern =%d [%t] %-5p [%c] - %m%n
    log4j.appender.DFile.Threshold = DEBUG
    
    #ERRORFile
    log4j.appender.EFILE = org.apache.log4j.FileAppender
    log4j.appender.EFILE.File = C://ERROR.log
    log4j.appender.EFILE.layout = org.apache.log4j.PatternLayout
    log4j.appender.EFILE.layout.ConversionPattern =%d [%t] %-5p [%c] - %m%n
    log4j.appender.EFILE.Threshold = ERROR

    rootLogger里配置DEBUG,
    DFile的Threshold 配置为DEBUG
    EFILE的Threshold 配置为ERROR 只输入ERROR信息;

    Log4j Append属性指定是否追加内容

    Log4j默认是不断的把日志内容追加到日志文件;
    这里就有个属性 Append 默认就是true;
    假如我们设置成false 就不追加了 直接覆盖前面的内容;

    http://blog.java1234.com/blog/q.html

  • 相关阅读:
    201521123095 《Java程序设计》第11周学习总结
    201521123095 《Java程序设计》第10周学习总结
    201521123095 《Java程序设计》第9周学习总结
    201521123095 《Java程序设计》第8周学习总结
    201521123095 《Java程序设计》第7周学习总结
    201521123095 《Java程序设计》第6周学习总结
    201521123095 《Java程序设计》第5周学习总结
    网络软工15个人作业5
    软工网络15个人作业4
    集大通APP案例分析
  • 原文地址:https://www.cnblogs.com/chong-zuo3322/p/13081859.html
Copyright © 2011-2022 走看看