Chinaunix首页 | 论坛 | 博客
  • 博客访问: 534991
  • 博文数量: 260
  • 博客积分: 10435
  • 博客等级: 上将
  • 技术积分: 1939
  • 用 户 组: 普通用户
  • 注册时间: 2009-11-24 14:50
文章分类

全部博文(260)

文章存档

2011年(22)

2010年(209)

2009年(29)

我的朋友

分类: Java

2010-06-18 14:46:02

l       什么是log4j?

Log4JApache 的一个开源项目,是一个在我们编写代码过程提供实现日志输出功能的包。Log4J 可以实现通过配置的方式日志输出、日志目的地定义、日志格式定 义 等功能,有效的管理日志。在使用Log4J 之前先看一下几个概念:

 

l       log4j 基本概念

在使用Log4j 之前,先看看3 个基本概念:Looger,Appender,PatternLayout

 

 

    三者关系如下:

三者关系图

图 1:Logger,Appender,PatternLayout关系图

 

    1. Logger 日志输出器,提供输出日志功能。

Log4J 内置了7Log 等级,从低到高分别为ALL, DEBUG, INFO, WARN, ERROR, FATAL, OFF 。每个Logger 都要默认定义一个等级。同时对于每一条要输出的日志也定义了等级,不同等级的日志用不同的方法调用,共5 种等级(DEBUG, INFO, WARN, ERROR, FATAL), 通过如下方法写出日志:

Logger logger=Logger.getLogger( logname);

logger.info(“…”);

logger.error(“…”);

logger.debug(“…”);

logger.warn(“…”);

logger.fatal(“…”);

如果日志的等级高于等于日志输出器的等级,那么该日志才会被写入。

    2.Appender 日志目的地,用来定义日志目的地对象。

在日志写出之前还必须先定义好日志器对应的日志目的地。一个日志器可以定义多个目的地。日志目的地有多种类型。其结构如下:

 

 

Appender结构图

图2:Appender结构图

 

其中Appender 是顶层接口,下面定义了很多种Appender ,几种常见的Appender 解释如下:

 

ConsoleAppender: 控制台作为日志输出地

FileAppender: 文件作为日志输出地

RollingFileAppender: 日志文件的大小受到限制,当内容超出最大的限制时,该文件将向上滚动。

其他的类型笔者也未曾深入研究。

    3.PatternLayout :日志布局,用于定义日志格式。

定义日志布局,指定在日志输出到目的地的时候以怎样的格式被输出。

 

l       3. 如何使用Log4J

无论你是否创建 logger Log4J 都会默认创建一个 RootLogger ,该日志器可以通过 Logger.getRootLogger() 获得。所以的 logger 都将继承该根 Logger.

在使用 Log4j 进行日志记录之前必须先初始化 Log4J 配置,配置可以包含如下工作:

定义日志器 logger ,如:

定义指定 Layout appender

定义 logger 对应的 appender

Log4j 可以通过如下两种方式进行初始化

a. 默认配置

org.apache.log4j.BasicConfigurator .configure ();

它将完成如下工作:

  • 用默认 pattern 创建 PatternLayout 对象 p
    PatternLayout p = new PatternLayout("%-4r[%t]%-5p%c%x - %m%n");
  • p 创建 ConsoleAppender 对象 a ,目标是 system.out ,标准输出设备:
    ConsoleAppender a = new ConsoleAppender(p,ConsoleAppender.SYSTEM_OUT);
  • root logger 增加一个 ConsoleAppender p
    rootLogger.addAppender(p);
  • root logger log level 设置为 DEBUG 级别:
    rootLogger.setLevel(Level.DEBUG);

b. 自定义配置

这个是比较推荐也比较常用的一种配置。可以将配置定义在程序之外,在程序之外控制日志系统的运行。主要通过 XML 文件配置。由 org.apache.log4j.xml.DOMConfigurator.configure() 方法读入配置并初始化。 org/apache/log4j/xml/log4j.dtd 里定义了 XML 文件的语法。下面简单介绍如何在 XML 文件里定义 Logger Appender root 配置及两者关系等。

定义 Logger( 注:同名的 logger Log4J 里只会有一个对象 )

  1. < logger  name = "fileLogger" >  logger 名称  
  2.        < level value = "debug" /> logger 级 别  
  3.        < appender-ref ref = "file.log" /> logger 对 应的 appender  
  4.  logger >  
  5. 定义 appender:  
  6.     < appender name = "file.log" class = "org.apache.log4j.FileAppender" >  
  7.        < param name = "File" value = "/tmp/log.txt" /> 对应文件  
  8.        < param name = "Append" value = "false" />       每 次是否清空  
  9.        < layout class = "org.apache.log4j.PatternLayout" > 日志格式  
  10.            < param name = "ConversionPattern" value = "%d [%t] %p - %m%n" />  
  11.         layout >  
  12.  appender >  
  13. Root 配 置  
  14.    < root >  
  15.        < level value = "debug" />  
  16.        < appender-ref ref = "console.log" />  
  17.      root >   

 

以上是关于 Log4J 的一些概念和使用介绍。 下面举两个简单例子说明:

例子 1 使用 BasicConfigurator.congigure() 初始化

Log4JTest.java:

  1. import  org.apache.log4j.Level;  
  2. import org.apache.log4j.Logger;  
  3.    
  4. public class Log4JTest {  
  5.     public static void main(String argv[]) {  
  6.      
  7.         // Create a logger by the name of class Log4jTest.  
  8.         Logger logger = Logger.getLogger (Log4JTest. class );  
  9.    
  10.         // Use the default configuration.  
  11.         org.apache.log4j.BasicConfigurator.configure ();  
  12.    
  13.         // Set the logger level to Level.INFO  
  14.         logger.setLevel(Level. INFO );  
  15.    
  16.         // This request will be disabled since Level.DEBUG < Level.INFO.  
  17.         logger.debug( "This is debug." );  
  18.    
  19.         // These requests will be enabled.  
  20.         logger.info( "This is an info." );  
  21.         logger.warn( "This is a warning." );  
  22.         logger.error( "This is an error." );  
  23.         logger.fatal( "This is a fatal error." );  
  24.          
  25.         return ;  
  26.     }  
  27. }   

 

例子 2 使用 XML 文件配置

Log4j_config.XML:

 

  1.  xml  version = "1.0"  encoding = "UTF-8"  ?>  
  2. >  
  3.    
  4. < log4j:configuration xmlns:log4j = "" >  
  5.    
  6.       
  7.     < appender name = "file.log" class = "org.apache.log4j.FileAppender" >  
  8.        < param name = "File" value = "/tmp/log.txt" />  
  9.        < param name = "Append" value = "false" />  
  10.        < layout class = "org.apache.log4j.PatternLayout" >  
  11.            < param name = "ConversionPattern" value = "%d [%t] %p - %m%n" />  
  12.         layout >  
  13.      appender >  
  14.       
  15.     < appender name = "file_roll.log" class = "org.apache.log4j.RollingFileAppender" >  
  16.        < param name = "File" value = "/tmp/fileRoll.log" />  
  17.        < param name = "Append" value = "false" />  
  18.        < layout class = "org.apache.log4j.PatternLayout" >  
  19.            < param name = "ConversionPattern" value = "%d [%t] %p - %m%n" />  
  20.         layout >  
  21.      appender >  
  22.       
  23.     < appender name = "console.log" class = "org.apache.log4j.ConsoleAppender" >  
  24.        < layout class = "org.apache.log4j.PatternLayout" >  
  25.            < param name = "ConversionPattern" value = "%d [%t] %p - %m%n" />  
  26.         layout >  
  27.      appender >  
  28.    
  29.    
  30.     < logger name = "fileLogger" >  
  31.        < level value = "debug" />  
  32.        < appender-ref ref = "file.log" />  
  33.      logger >  
  34.    
  35.       
  36.     < root >  
  37.        < level value = "debug" />  
  38.        < appender-ref ref = "console.log" />  
  39.      root >    
  40.  log4j:configuration >  

 

Log4JXMLTest.java:

 

  1. import org.apache.log4j.Level;  
  2. import org.apache.log4j.Logger;  
  3. import org.apache.log4j.xml.DOMConfigurator;  
  4.    
  5. public class Log4JXMLTest {  
  6.        public static void main(String args[]) {  
  7.               DOMConfigurator.configure("log4j_config.xml");  
  8.               Logger fileLogger = Logger.getLogger("fileLogger");  
  9.               fileLogger.setLevel(Level.ALL);  
  10.               fileLogger.debug("i just make a test!");  
  11.               Logger.getRootLogger();  
  12.        }  
  13. }   

以上是关于 Log4J 的一些基本介绍,笔者认为日志对一个应用的作用应该是巨大的,当然也会带来一定的系统开 销,但是这是值得的。同时 Log4J 提供的可配置的日志系统管理,方便易用,推荐大家使用。

 

阅读(638) | 评论(0) | 转发(0) |
0

上一篇:java quartz thread

下一篇:java quartz 名词 介绍

给主人留下些什么吧!~~