【永恒的瞬间】
☜Give me hapy ☞
在应用程序中输出日志有有三个目的:

(1)监视代码中变量的变化情况,把数据周期性地记录到文件中供其他应用进行统计分析工作。

(2)跟踪代码运行进轨迹,作为日后审计的依据。

(3)担当集成开发环境中的调试器,向文件或控制台打印代码的调试信息。

  Apache能用日志包(Commons Logging Package)是Apache的一个开放源代码项目,它提供了一组通用的日志接口,用户可以自由地选择实现日志接口的第三方软件。通用日志包目前支持以下日志实现:

  • Log4J日志器(http://jakarta.apache.org/log4j
  • JDK1.4 Logging日志器(JDK1.4自带)
  • SimpleLog日志器(把日志消息输出到标准系统错误流System.err)
  • NoOpLog(不输出任何日志信息)

通用日志包中的两个常用接口:LogFactory和Log,分别介绍如下:

  • Log接口

通用日志包把消息分为6个级别:FATAL、ERROR、WARN、INFO、DEBUG和TRACE。其中FATAL级别最高,TRACE级别最低。Log接口提供输出不同级别消息的方法:

fatal(Object message)-------输出FATAL级别的消息。

error(Object message)-------输出ERROR级别的消息。

warn(Object message)-------输出WARN级别的消息。

info(Object message)-------输出INFO级别的消息。

debug(Object message)-------输出DEBUG级别的消息。

trace(Object message)-------输出TRACE级别的消息。

注:只有当输出日志的级别大于或等于为日志配置器配置的日志级别时,这个方法才会执行。

  如何指定日志器的日志级别,不同的日志器实现会有不同的实现方案。

  • LogFactory接口

LogFactory接口提供了获得日志器实例的两个静态方法:

public static Log getLog(String name) throws LogConfigurationException;

public static Log getLog(Class class) throws LogConfigurationException;

注:name参数作为日志器的名字;class参数指定类名作为日志器名字。

以下介绍最常用的一个日志实现--------Log4J

  Log4j是Apache的一个开放源代码项目,它是一个日志操作包。通过使用Log4j,我们可以控制日志信息输送的目的地是控制台、文件、GUI组件、甚至是套接口服务器、NT的事件记录器、UNIX Syslog守护进程等;我们也可以控制每一条日志的输出格式;通过定义每一条日志信息的级别,我们能够更加细致地控制日志的生成过程。最令人感兴趣的就是,这些可以通过一个配置文件来灵活地进行配置,而不需要修改应用的代码。
此外,通过Log4j其他语言接口,您可以在C、C++、.Net、PL/SQL程序中使用Log4j,其语法和用法与在Java程序中一样,使得多语言分布式系统得到一个统一一致的日志组件模块。而且,通过使用各种第三方扩展,您可以很方便地将Log4j集成到J2EE、JINI甚至是SNMP应用中。

  Log4J主要由三大组件构成:

  • Logger:负责生成日志,并能根据配置的日志级别来决定什么日志消息应该被输出,什么日志消息应该被忽略。
  • Appender:定义日志消息输出的目的地,指定日志消息应该被输出到什么地方,这些地方可以是控制台、文件和网络设备等。
  • Layout:指定日志消息的输出格式。

  这三个组件协同工作,使得开发者能够依据日志消息类别来输出日志,并能够在程序运行期间,控制日志消息的输出格式以及日志存放地点。

  Log4J的配置

  配置Log4J,需要分别配置它的Logger、Appender和Layout属性。配置文件一般为log4j.properties。当然也可以以XML文件来配置,这里介绍以属性文件配置。

  • 配置Logger组件

Logger组件支持继承关系,所有的Logger组件都直接或间接继承rootLogger。配置rootLogger的语法为:

  log4j.rootLogger=[priority],appenderName,appenderName,......

priority是如前所述的日志级别;

appenderName指定Appender组件,用户可以同时指定多个Appender组件,以与逗号分隔。

  • 配置Appender组件

配置日志消息输出目的地Appender,语法为:

  log4j.appender.appenderName=<appender的完整类名>

  log4j.appender.appenderName.option1=value1

  log4j.appender.appenderName.option2=value2

  ...

Log4J共有以下几种Appender:

  org.apache.log4j.ConsoleAppender(控制台)

  org.apache.log4j.FileAppender(文件)

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

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

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

  • 配置Layout组件

语法:

   log4j.appender.appenderName.layout=<layout的完整类名>

   log4j.appender.appenderName.layout.option1=value1

   log4j.appender.appenderName.layout.option2=value2

   ...

Log4J提供以下几种Layout:

  org.apache.log4j.HTMLLayout(以HTML表格形式布局)

  org.apache.log4j.PatternLayout(可以灵活地指定布局模式)

  org.apache.log4j.SimpleLayout(包含日志消息的级别和信息字符串)

  org.apache.log4j.TTCCLayout(包含日志产生的时间、线程和类别等信息)

通过设置PatternLayout的ConversionPattern属性来指定输出格式

ConversionPattern的格式如下表所示:

格式名      含义
%c       输出日志信息所属的类的全名
%d      输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:

                            %d{yyy-MM-dd HH:mm:ss },输出类似:2002-10-18- 22:10:28
%f       输出日志信息所属的类的类名
%l       输出日志事件的发生位置,即输出日志信息的语句处于它所在的类的第几行
%m        输出代码中指定的信息,如log(message)中的message
%n      输出一个回车换行符,Windows平台为“\r\n”,Unix平台为“\n”
%p      输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL。如果是调用debug()输出的,则为DEBUG,依此类推
%r      输出自应用启动到输出该日志信息所耗费的毫秒数
%t      输出产生该日志事件的线程名


示例:log4j.appender.file.layout=org.apache.log4j.PatternLayout

   log4j.appender.file.layout.ConversionPattern=%t %p- %m%n

Log4J对应用性能的影响

  如果在程序运行中输出大量日志,显然会对应用的性能造成一定的影响。Log4J对性能的影响取决于以下因素:

  • 日志输出目的地:输出到控制台的速度和输出到文件系统的速度是不一样的。
  • 日志输出格式:格式简单,速度也更快。
  • 日志级别:日志级别设置的越低,输出的日志内容越多,对性能的影响也越大。
posted on 2007-01-03 16:46 ☜♥☞MengChuChen 阅读(947) 评论(0)  编辑  收藏 所属分类: Log4j

只有注册用户登录后才能发表评论。


网站导航: