log4j配置详解

     Log4j 是做什么的

       Log4j是Apache的一个开放源代码项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台、文件、GUI组件、甚至是套接口服务器、NT的事件记录器、UNIX Syslog守护进程等;我们也可以控制每一条日志的输出格式;通过定义每一条日志信息的级别,能够更加细致地控制日志的生成过程,而这些可以通过一个配置文件来灵活地进行配置,不需要修改应用的代码。Log4j是Apache的一个开放源代码项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台、文件、GUI组件、甚至是套接口服务器、NT的事件记录器、UNIX Syslog守护进程等;我们也可以控制每一条日志的输出格式;通过定义每一条日志信息的级别,能够更加细致地控制日志的生成过程,而这些可以通过一个配置文件来灵活地进行配置,不需要修改应用的代码。

     log4j必须要掌握的三个组件

    (1) Logger : 负责输出信息日志信息,并能够对日志信息过滤,确定哪些日志信息输出,哪些信息被忽略。
    (2) Appender : 指定日志输出到什么地方,可以是控制台、文件或网络设备等等。
    (3) Layouts : 加在Appender后面用以实现格式化输出日志的内容。

   log4j设置

     (1) 下载log4j软件包(官网下载地址: Apache log4j)
     (2) 引入下载log4j的jar包到lib目录。
     (3)在CLASSPATH下建立log4j.properties或XML格式的配置文件。
     配置文件如下:
</pre><pre name="code" class="html"><span style="font-family: Arial;font-size:10px; line-height: 26px; background-color: rgb(238, 238, 238);">#配置根Logger</span>
log4j.rootLogger = debug,stdout,E

<span style="font-family: Arial;font-size:10px; line-height: 26px; background-color: rgb(238, 238, 238);"><span style="font-family: Arial;font-size:10px; line-height: 26px; background-color: rgb(238, 238, 238);">### 输出到控制台 ###</span></span>
log4j.appender.stdout = org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Threshold = debug
log4j.appender.stdout.Target = System.out
log4j.appender.stdout.layout = org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern =  %d{ABSOLUTE} %5p %c{1}:%L - %m%n

<span style="font-family: Arial;font-size:10px; line-height: 26px; background-color: rgb(238, 238, 238);">### 输出到日志文件 ###</span>
log4j.logger.org.hibernate.cache=debug
log4j.appender.E= org.apache.log4j.DailyRollingFileAppender
log4j.appender.E.File =C:/LOG4J/logs/log_
log4j.appender.E.DatePattern=yyyy-MM-dd'.log'
log4j.appender.E.Threshold = debug
log4j.appender.E.layout = org.apache.log4j.PatternLayout
log4j.appender.E.layout.ConversionPattern =%-d{yyyy-MM-dd HH\:mm\:ss}[%c] [%t\:%r] - [%p]  %m%n

log4j配置文件详解 

(一) log4j.rootLogger的第一个参数为输出日志的级别,下面是其五个级别:
  FATAL         0           
  ERROR      3           
  WARN        4           
  INFO           6          
  DEBUG      7         
 log4j.rootLogger后面的两个参数意为将等级为debug的日志信息输出到stdout和E这两个目的地,stdout和E的定义在下面的代码,可以任意起名。        
 定义为stdout的输出端可以是以下五种:           
   (1)org.apache.log4j.ConsoleAppender(控制台)           
   (2)org.apache.log4j.FileAppender(文件)           
   (3)org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件)           
   (4)org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件)           
   (5)org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)       
  定义为E的输出端解释如下:          
   log4j.appender.E= org.apache.log4j.DailyRollingFileAppender,定义名为E的输出端的类型为每天产生一个日志文件。        
   log4j.appender.E.File =C:/LOG4J/logs/log_,此句为定义名为E的输出端的文件名为C:/LOG4J/logs/log_。      
   log4j.appender.E.DatePattern=yyyy-MM-dd'.log',日志后缀格式。         
   log4j.appender.E.Threshold = debug,只输出debug以上级别的日志。          
   log4j.appender.E.layout = org.apache.log4j.PatternLayout,此句为定义名为stdout的输出端的layout是哪种类型。可以是以下4种类型:              
    (1) org.apache.log4j.HTMLLayout(以HTML表格形式布局)                
    (2) org.apache.log4j.PatternLayout(可以灵活地指定布局模式)               
    (3)org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串)                
    (4)org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)
  log4j.appender.E.layout.ConversionPattern =%-d{yyyy-MM-dd HH\:mm\:ss}[%c] [%t\:%r] - [%p]  %m%n,如果使用pattern布局就要指定的打印信息的具体格式                             ConversionPattern,打印参数如下:               
    (1) %m 输出代码中指定的消息               
    (2)%p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL                 
    (3) %r 输出自应用启动到输出该log信息耗费的毫秒数               
    (4) %c 输出所属的类目,通常就是所在类的全名                
    (5) %t 输出产生该日志事件的线程名               
    (6) %n 输出一个回车换行符,Windows平台为“rn”,Unix平台为“n”               
    (7)%d 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyyy MMM dd HH:mm:ss,SSS},输出类似:2014年12月10日 22:                       10:28,921                 
    (8)%l 输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数。
   (二) log4j的其他参数说明:        
      log4j.logger.org.hibernate.cache=debug,指定org.hibernate.cache包下的所有类的等级为DEBUG。
      log4j.appender.stdout.Threshold = debug,输出DEBUG级别以上的日志。

  在代码中使用log4

 (1)导入所有需的commongs-logging类:         

    import org.apache.commons.logging.Log         

     import org.apache.commons.logging.LogFactory;  
 (2)在自己的类中定义一个org.apache.commons.logging.Log类的私有静态类成员:      
   private final Log log = LogFactory.getLog(getClass());        
   LogFactory.getLog()方法的参数使用的是当前类的class。   
 (3)使用org.apache.commons.logging.Log类的成员方法输出日志信息: 
public class HMain {
    static Logger log4j = Logger.getLogger(HMain.class.getClass());  
    public HMain(){
        System.out.println("hello, I am HMain");    
        printLog();
    }  
    private void printLog(){
        BasicConfigurator.configure();
        PropertyConfigurator.configure( " D:/Code/conf/log4j.properties " );     
        DOMConfigurator.configure("");   
        log4j.debug("log4j debug");
        log4j.info("log4j info");
        log4j.warn("log4j warn");
        log4j.error("log4j error");
        log4j.fatal("log4j fatal");
    }
}




   


你可能感兴趣的:(spring,log4j,mvc,debug,logging)