log4j使用简介
最近在整理公司产品的日志输出规范,涉及log4j的使用介绍,就简单整理了一下。
Log4j可以通过java程序动态设置,该方式明显缺点是:如果需要修改日志输出级别等信息,则必须修改java文件,然后重新编译,很是麻烦;
log4j也可以通过配置文件的方式进行设置,目前支持两种格式的配置文件:
下面是一个log4j配置文件的完整内容:
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主要定义日志信息输出在什么位置,主要语法为:
Log4j提供的appender有以下几种:
以ConsoleAppender为例,如:
1.4配置日志信息的格式Layout
Layout 负责格式化Appender的输出,其语法为:
其中,Log4j提供的layout有以下几种:
可以设置不同package的日志输出级别,语法为:
log4j.logger.packageName=level
其中,packageName为实际的包名,level为日志级别,例如:
Spring真是不错,替我们做了很多事情,如果系统使用了spring框架,则要集成log4j就很简单了,主要分为3个步骤,如下:
2.1.2定义监听器
监听器需要定义在web.xml,主要包括:定义log4j配置文件目录、log4j监听器,如下:
2.1.3测试类
如果系统没有使用spring,我们以servlet为例,很简单,大家按照步骤执行即可,只贴代码,不说废话。
放在web工程的WEB-INF目录下,内容如:
2.2.2创建log4j初始化类
2.2.3在Web.xml中定义初始化类
2.2.4测试类