Chinaunix首页 | 论坛 | 博客
  • 博客访问: 640274
  • 博文数量: 233
  • 博客积分: 2221
  • 博客等级: 大尉
  • 技术积分: 3184
  • 用 户 组: 普通用户
  • 注册时间: 2010-02-16 14:01
个人简介

瓜瓜派的瓜瓜

文章分类

全部博文(233)

文章存档

2013年(28)

2012年(197)

2011年(8)

分类:

2012-01-09 16:45:55

最近在整理公司产品的日志输出规范,涉及log4j的使用介绍,就简单整理了一下。

1 Log4j配置说明
1.1 配置文件
    Log4j可以通过java程序动态设置,该方式明显缺点是:如果需要修改日志输出级别等信息,则必须修改java文件,然后重新编译,很是麻烦;

    log4j也可以通过配置文件的方式进行设置,目前支持两种格式的配置文件:

xml文件 
properties文件(推荐) 
下面是一个log4j配置文件的完整内容:

view plaincopy to clipboardprint?
log4j.rootCategory=INFO, stdout   
log4j.rootLogger=info, stdout   
    
### stdout ###   
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=%d{ABSOLUTE} %5p - %m%n   
    
### set package ###   
log4j.logger.org.springframework=info  
log4j.logger.org.apache.catalina=info  
log4j.logger.org.apache.commons.digester.Digester=info  
log4j.logger.org.apache.catalina.startup.TldConfig=info  
log4j.logger.chb.test=debug  
log4j.rootCategory=INFO, stdout
log4j.rootLogger=info, stdout

### stdout ###
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=%d{ABSOLUTE} %5p - %m%n

### set package ###
log4j.logger.org.springframework=info
log4j.logger.org.apache.catalina=info
log4j.logger.org.apache.commons.digester.Digester=info
log4j.logger.org.apache.catalina.startup.TldConfig=info
log4j.logger.chb.test=debug 

1.2 配置根Logger

根logger主要定义log4j支持的日志级别及输出目的地,其语法为:

log4j.rootLogger = [ level ] , appenderName, appenderName, …

其中,level 是日志记录的优先级,分为OFF、FATAL、ERROR、WARN、INFO、DEBUG、ALL或者自定义的级别。

建议只使用四个级别,优先级从高到低分别是ERROR、WARN、INFO、DEBUG。

appenderName指定日志信息输出到哪个地方,可同时指定多个输出目的地。

1.3 配置输出目的地Appender

Appender主要定义日志信息输出在什么位置,主要语法为:

view plaincopy to clipboardprint?
log4j.appender.appenderName = classInfo  
log4j.appender.appenderName.option1 = value1  
  …   
log4j.appender.appenderName.optionN = valueN  
log4j.appender.appenderName = classInfo
log4j.appender.appenderName.option1 = value1
  …
log4j.appender.appenderName.optionN = valueN 

Log4j提供的appender有以下几种: 

org.apache.log4j.ConsoleAppender(控制台),  
org.apache.log4j.FileAppender(文件),  
org.apache.log4j.DailyRollingFileAppender(每天产生一个日志文件), 
org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件)  
org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方) 
以ConsoleAppender为例,如:

view plaincopy to clipboardprint?
log4j.appender.stdout=org.apache.log4j.ConsoleAppender   
log4j.appender.stdout.Target=System.out  
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target=System.out 

1.4 配置日志信息的格式Layout

  Layout 负责格式化Appender的输出,其语法为:

view plaincopy to clipboardprint?
log4j.appender.appenderName.layout = classInfo  
log4j.appender.appenderName.layout.option1 = value1  
…   
log4j.appender.appenderName.layout.optionN = valueN  
log4j.appender.appenderName.layout = classInfo
log4j.appender.appenderName.layout.option1 = value1

log4j.appender.appenderName.layout.optionN = valueN 

  其中,Log4j提供的layout有以下几种: 

org.apache.log4j.HTMLLayout(以HTML表格形式布局),  
org.apache.log4j.PatternLayout(可以灵活地指定布局模式),  
org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串) 
org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息) 
1.5 设置package输出级别
可以设置不同package的日志输出级别,语法为:

log4j.logger.packageName=level

其中,packageName为实际的包名,level为日志级别,例如:

view plaincopy to clipboardprint?
log4j.logger.org.springframework=info  
log4j.logger.org.apache.catalina=info  
log4j.logger.org.apache.commons.digester.Digester=info  
log4j.logger.org.apache.catalina.startup.TldConfig=info  
log4j.logger.chb.test=debug  
log4j.logger.org.springframework=info
log4j.logger.org.apache.catalina=info
log4j.logger.org.apache.commons.digester.Digester=info
log4j.logger.org.apache.catalina.startup.TldConfig=info
log4j.logger.chb.test=debug 

2 Log4j与J2ee结合
2.1 使用spring架构
Spring真是不错,替我们做了很多事情,如果系统使用了spring框架,则要集成log4j就很简单了,主要分为3个步骤,如下:

2.1.1 定义log4j配置文件
view plaincopy to clipboardprint?
log4j.rootCategory=INFO, stdout   
log4j.rootLogger=info, stdout   
    
### stdout ###   
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=%d{ABSOLUTE} %5p - %m%n   
    
### log to file ###   
log4j.logger.org.springframework=info  
log4j.logger.org.apache.catalina=info  
log4j.logger.org.apache.commons.digester.Digester=info  
log4j.logger.org.apache.catalina.startup.TldConfig=info  
log4j.logger.chb.test=debug  
log4j.rootCategory=INFO, stdout
log4j.rootLogger=info, stdout

### stdout ###
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=%d{ABSOLUTE} %5p - %m%n

### log to file ###
log4j.logger.org.springframework=info
log4j.logger.org.apache.catalina=info
log4j.logger.org.apache.commons.digester.Digester=info
log4j.logger.org.apache.catalina.startup.TldConfig=info
log4j.logger.chb.test=debug 

2.1.2  定义监听器

监听器需要定义在web.xml,主要包括:定义log4j配置文件目录、log4j监听器,如下:

view plaincopy to clipboardprint?
  
    xmlns=""  
    xmlns:xsi=""  
    xsi:schemaLocation="   
    ">  
      
      
      
       log4jConfigLocation  
       /WEB-INF/log4j.properties  
   
  
      
      
       contextConfigLocation  
         
           /WEB-INF/classes/applicationContext*.xml   
      
  
   
  
      
      
      
         
           org.springframework.web.util.Log4jConfigListener   
      
  
   
  
      
      
         
           org.springframework.web.context.ContextLoaderListener   
      
  
   
  
      
      
       InitiaServlet  
    chb.test.web.InitiaServlet  
       1  
   
  
      
    
    index.jsp  
  
  
  

    xmlns=""
    xmlns:xsi=""
    xsi:schemaLocation="
    ">
   
   
   
       log4jConfigLocation
       /WEB-INF/log4j.properties
   

   
   
       contextConfigLocation
      
           /WEB-INF/classes/applicationContext*.xml
      

   

   
   
   
      
           org.springframework.web.util.Log4jConfigListener
      

   

   
   
      
           org.springframework.web.context.ContextLoaderListener
      

   

   
   
       InitiaServlet
    chb.test.web.InitiaServlet
       1
   

   
  
    index.jsp
  

 

2.1.3  测试类

view plaincopy to clipboardprint?
package com.dheaven.mip.web;   
    
    
import javax.servlet.ServletException;   
import javax.servlet.http.HttpServlet;   
    
import org.apache.log4j.Logger;   
    
public class InitiaServlet extends HttpServlet {   
      
    protected Logger log = Logger.getLogger(InitiaServlet.class);   
    
    private static final long serialVersionUID = 8550329576989690578L;   
    
    /**  
     * Constructor of the object.  
     */  
    public InitiaServlet() {   
       super();   
    }   
    
    /**  
     * Destruction of the servlet.
  
     */  
    public void destroy() {   
       super.destroy();   
    }   
    
    /**  
     * Initialization of the servlet.
  
     *  
     * @throws ServletException if an error occure  
     */  
    public void init() throws ServletException {   
       log.debug("服务器启动了,log4j开始工作了");   
    }   
}  
package com.dheaven.mip.web;


import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;

import org.apache.log4j.Logger;

public class InitiaServlet extends HttpServlet {
   
    protected Logger log = Logger.getLogger(InitiaServlet.class);

    private static final long serialVersionUID = 8550329576989690578L;

    /**
     * Constructor of the object.
     */
    public InitiaServlet() {
       super();
    }

    /**
     * Destruction of the servlet.

     */
    public void destroy() {
       super.destroy();
    }

    /**
     * Initialization of the servlet.

     *
     * @throws ServletException if an error occure
     */
    public void init() throws ServletException {
       log.debug("服务器启动了,log4j开始工作了");
    }


2.2不使用spring架构
如果系统没有使用spring,我们以servlet为例,很简单,大家按照步骤执行即可,只贴代码,不说废话。

2.2.1 定义log4j配置文件
放在web工程的WEB-INF目录下,内容如:

view plaincopy to clipboardprint?
log4j.rootCategory=INFO, stdout   
log4j.rootLogger=info, stdout   
    
### stdout ###   
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=%d{ABSOLUTE} %5p - %m%n   
    
### set package ###   
log4j.logger.org.apache.catalina=info  
log4j.logger.org.apache.commons.digester.Digester=info  
log4j.logger.org.apache.catalina.startup.TldConfig=info  
log4j.logger.com.dheaven=debug  
log4j.rootCategory=INFO, stdout
log4j.rootLogger=info, stdout

### stdout ###
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=%d{ABSOLUTE} %5p - %m%n

### set package ###
log4j.logger.org.apache.catalina=info
log4j.logger.org.apache.commons.digester.Digester=info
log4j.logger.org.apache.catalina.startup.TldConfig=info
log4j.logger.com.dheaven=debug 

2.2.2  创建log4j初始化类

view plaincopy to clipboardprint?
package com.dheaven.mip.web;   
    
import javax.servlet.ServletException;   
import javax.servlet.http.HttpServlet;   
    
import org.apache.log4j.PropertyConfigurator;   
    
public class InitLog4j extends HttpServlet {   
    
    private static final long serialVersionUID = 1L;   
    
    public void init() throws ServletException {   
       String prefix = getServletContext().getRealPath("/");   
       prefix = prefix.replace("\\", "/");   
       String file = getInitParameter("log4j-init-file");   
       // if the log4j-init-file is not set, then no point in trying   
       if (file != null) {   
           PropertyConfigurator.configure(prefix + file);   
       }   
    }   
}  
package com.dheaven.mip.web;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;

import org.apache.log4j.PropertyConfigurator;

public class InitLog4j extends HttpServlet {

    private static final long serialVersionUID = 1L;

    public void init() throws ServletException {
       String prefix = getServletContext().getRealPath("/");
       prefix = prefix.replace("\\", "/");
       String file = getInitParameter("log4j-init-file");
       // if the log4j-init-file is not set, then no point in trying
       if (file != null) {
           PropertyConfigurator.configure(prefix + file);
       }
    }


2.2.3  在Web.xml中定义初始化类

view plaincopy to clipboardprint?
  
   log4j-init  
   chb.test.web.InitLog4j  
  
     
       log4j-init-file  
       WEB-INF/log4j.properties  
   
  
     
   1  
  
   
       log4j-init
       chb.test.web.InitLog4j

      
           log4j-init-file
           WEB-INF/log4j.properties
      

      
       1
   
 

2.2.4 测试类

view plaincopy to clipboardprint?
package chb.test.web;   
    
    
import javax.servlet.ServletException;   
import javax.servlet.http.HttpServlet;   
    
import org.apache.log4j.Logger;   
    
public class InitiaServlet extends HttpServlet {   
      
    protected Logger log = Logger.getLogger(InitiaServlet.class);   
    
    private static final long serialVersionUID = 8550329576989690578L;   
    
    /**  
     * Constructor of the object.  
     */  
    public InitiaServlet() {   
       super();   
    }   
    
    /**  
     * Destruction of the servlet.
  
     */  
    public void destroy() {   
       super.destroy();   
    }   
    
    /**  
     * Initialization of the servlet.
  
     *  
     * @throws ServletException if an error occure  
     */  
    public void init() throws ServletException {   
       log.debug("服务器启动了,log4j开始工作了");   
    }   
}
阅读(819) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~