在应用程序中输出日志有有三个目的:
(1)监视代码中变量的变化情况,把数据周期性地记录到文件中供其他应用进行统计分析工作。
(2)跟踪代码运行进轨迹,作为日后审计的依据。
(3)担当集成开发环境中的调试器,向文件或控制台打印代码的调试信息。
Apache能用日志包(Commons Logging Package)是Apache的一个开放源代码项目,它提供了一组通用的日志接口,用户可以自由地选择实现日志接口的第三方软件。通用日志包目前支持以下日志实现:
通用日志包中的两个常用接口:LogFactory和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接口提供了获得日志器实例的两个静态方法:
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组件都直接或间接继承rootLogger。配置rootLogger的语法为:
log4j.rootLogger=[priority],appenderName,appenderName,......
priority是如前所述的日志级别;
appenderName指定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(将日志消息以流格式发送到任意指定的地方)
语法:
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