java中的日志操作方法---Log4J
2006-12-20 10:17
253 查看
在应用程序中输出日志有有三个目的:
(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对性能的影响取决于以下因素:
日志输出目的地:输出到控制台的速度和输出到文件系统的速度是不一样的。
日志输出格式:格式简单,速度也更快。
日志级别:日志级别设置的越低,输出的日志内容越多,对性能的影响也越大。
(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对性能的影响取决于以下因素:
日志输出目的地:输出到控制台的速度和输出到文件系统的速度是不一样的。
日志输出格式:格式简单,速度也更快。
日志级别:日志级别设置的越低,输出的日志内容越多,对性能的影响也越大。
相关文章推荐
- java日志组件介绍(common-logging,log4j,slf4j,logback )
- 【Log4j】Java日志记录的5条规则
- Java日志管理:Logger.getLogger()和LogFactory.getLog()的区别(详解Log4j)
- Java 使用Log4J进行日志操作
- java 日志记录使用slf4j优于log4j的原因
- java学习:log4j输出xml格式的日志文件
- java日志处理组件log4j--log4j.xml配置详解
- JAVA log4j日志基本运用
- java——log4j生成日志文件
- Java日志框架(Commons-logging,SLF4j,Log4j,Logback)
- java的日志工具log4j的配置方法
- Java日志,需要知道的几件事(commons-logging,log4j,slf4j,logback)
- [Java]log4j写SQL Server数据库日志的统一写法
- java日志,(commons-loging 、log4j 、slf4j 、LogBack介绍)
- java日志系统--log4j初识用法
- log4j配置文件及nutch中的日志配置 分类: B1_JAVA 2015-02-17 10:58 483人阅读 评论(0) 收藏
- .Java中的异常、断言、日志【草稿下,Log4j专题】
- Log4j——JAVA系统日志
- java日志组件介绍(common-logging,log4j,slf4j,logback )
- Log4j实现对Java日志的配置全攻略