• log4j使用总结


    转自1:http://blog.csdn.net/zdwzzu2006/article/details/6102145

    转自2:http://www.codeceo.com/article/log4j-usage.html

    1、src同级创建并设置log4j.properties 
    ### 设置###
    log4j.rootLogger = debug,stdout,D,E
    
    ### 输出信息到控制抬 ###
    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 = [%-5p] %d{yyyy-MM-dd HH:mm:ss,SSS} method:%l%n%m%n
    
    ### 输出DEBUG 级别以上的日志到=E://logs/error.log ###
    log4j.appender.D = org.apache.log4j.DailyRollingFileAppender
    log4j.appender.D.File = E://logs/log.log
    log4j.appender.D.Append = true
    log4j.appender.D.Threshold = DEBUG
    log4j.appender.D.layout = org.apache.log4j.PatternLayout
    log4j.appender.D.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss}  [ %t:%r ] - [ %p ]  %m%n
    
    ### 输出ERROR 级别以上的日志到=E://logs/error.log ###
    log4j.appender.E = org.apache.log4j.DailyRollingFileAppender
    log4j.appender.E.File =E://logs/error.log
    log4j.appender.E.Append = true
    log4j.appender.E.Threshold = ERROR
    log4j.appender.E.layout = org.apache.log4j.PatternLayout
    log4j.appender.E.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss}  [ %t:%r ] - [ %p ]  %m%n

    Log4j是apache的一个开源项目,用来操作程序日志信息的框架。因便于管理,在工程中用来代替System.out打印语句。通过配置Log4j中的log4j.properties,可以指定日志信息的级别,输出地点,输出格式。 
     Log4j的有3大主要组件:
          1,Logger:记录器,决定什么日志信息应该被输出、什么日志信息应该被忽略。
          2,Appender:存放器,指定日志信息应该输出到什么地方,可以是控制台、文件、网络设备。
          3,Layout:布局格式,指定日志信息的输出格式。
       一个logger可以用多个appender,也就是说日志信息可以同时输出到多个设备上,每个appender对应一种layout。
       所以,记录器用来整合日志信息,一个日志信息调整好以后,交给记录器的所有存放器,每一个存放器根据自己的格式输出日志信息。

    二、记录器组件Logger
       1.根记录器 : rootLogger
         配置语法 :log4j.rootLogger = [日志级别],存放器名1,存放器名2, ... ,存放器名N
         日志级别 :级别由高到低依次是:fatal、error、warn、info、debug。
         项目中代码:
     log4j.rootLogger=INFO, stdout, logfile  跟记录器的日子级别是info,所以info,warn,error,fatal均会被执行。stdout,logfile是存放器。

     2. 在配置文件中配置Logger组件
          可在Log4J配置文件中配置自己的Logger组件
          项目中代码:
          log4j.logger.Application=INFO,Application
          log4j.logger.Service=DEBUG,Service
          log4j.logger.jdbc=INFO,jdbc
          log4j.logger.Action=INFO,Action
          定义了application,service,jdbc,action四个自己的logger组件,并分别配置了级别和存放器。

    三、存放器组件Appender     配置语法 :

             log4j.appender.存放器名 = 存放类         

      log4j.appender.存放器名.option1 = value1     

      存放类:  org.apache.log4j.ConsoleAppender         控制台输出        

           org.apache.log4j.FileAppender          文件        

           org.apache.log4j.DailyRollingFileAppender 每天产生一个日志文件        

           org.apache.log4j.RollingFileAppender  文件大小到达指定尺寸的时候产生一个新的文件        

          org.apache.log4j.WriterAppender   将日志信息以流格式发送到任意指定的地方

     项目中代码: 
           Application记录器:
             log4j.appender.Application=org.apache.log4j.RollingFileAppender
             log4j.appender.Application.encoding=UTF-8
             log4j.appender.Application.File=/imagesys/logs/ImageCreditServer/ApplicationLog.log
             log4j.appender.Service.MaxFileSize=10240KB 

     Service记录器:
              log4j.appender.Service=org.apache.log4j.RollingFileAppender
              log4j.appender.Service.encoding=UTF-8
              log4j.appender.Service.File=/imagesys/logs/ImageCreditServer/ServiceLog.log
              log4j.appender.Service.MaxFileSize=10240KB
      jdbc记录器:
              log4j.appender.jdbc=org.apache.log4j.RollingFileAppender
              log4j.appender.jdbc.encoding=UTF-8
              log4j.appender.jdbc.File=/imagesys/logs/ImageCreditServer/jdbcLog.log
              log4j.appender.jdbc.MaxFileSize=1024KB
            action记录器:
              log4j.appender.Action=org.apache.log4j.RollingFileAppender
              log4j.appender.Action.encoding=UTF-8
              log4j.appender.Action.File=/imagesys/logs/ImageCreditServer/ActionLog.log
              log4j.appender.Action.MaxFileSize=10240KB

    分别制定了输出文件的存放类,编码方式,文件路径,文件大小。

    四、格式化组件Layout
           配置语法 :
           log4j.appender.存放器名.layout = 格式类
           log4j.appender.存放器名.layout.option1 = value1
            … …
           log4j.appender.存放器名.layout.optionN = valueN
           输出格式类型:
           . org.apache.log4j.HTMLLayout(以HTML表格形式布局);
           . org.apache.log4j.PatternLayout(可以灵活地指定布局模式);
           . org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串);
           . org.apache.log4j.TTCCLayout(包含日志产生的时间、线程和类别等信息);
           符号             描述
            %r          自程序开始后消耗的毫秒数
            %t          表示日志记录请求生成的线程
            %p          表示日志语句的优先级
            %r          与日志请求相关的类别名称
            %c          日志信息所在的类名
            %m%n        表示日志信息的内容
           项目中代码:
           log4j.appender.Application.layout=org.apache.log4j.PatternLayout
           log4j.appender.Application.layout.ConversionPattern=%d %p [%c] - %m%n
           以自定义的格式输出日志信息。

  • 相关阅读:
    SqlServer2016数据同步之使用发布/订阅功能同步数据
    .Net6+Furion+Sqlsugar+SenparcSdk开发微信公众号系列之二:搭建项目
    加速训练之 TFrecordsshard与并行化
    yomswmstmsbms 订单管理系统、仓库管理系统、运输管理系统、账单管理系统
    WPF文件下载帮助类
    前端知识学习05
    前端知识学习07
    使用express+nodejs+mysql实现一个简单的接口
    前端知识学习06
    http中的Get、Post、Put、Delete的区别
  • 原文地址:https://www.cnblogs.com/linbo3168/p/6639823.html
Copyright © 2020-2023  润新知