Log4J配置文件用法

配置根Logger

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


当[level]设置为ALL时,则输出所有级别的日志,而当[level]设置为INFO的时候,则输出优先级相等或高于INFO级别的日志,以此类推,这里再次说明log4j里的优先级定义从低至高为: DEBUG 、INFO 、WARN 、ERROR 、FATAL。定义为OFF时则不做任何输出。

设置一个appender

log4j.appender.[NAME]=org.apache.log4j.ConsoleAppender


这里的[NAME]就是上句[appenderName]所选的名称,可以理解为日志输出目的地的名字,名称可以随意取,我们知道日志可以输出到多个地方,比如可以输出到控制台,生成日志文件等。

log4j提供以下几种appender:

//控制台
org.apache.log4j.ConsoleAppender
//文件
org.apache.log4j.FileAppender
//可以设置目标文件的大小,当文件到达这个尺寸的时候自动生成一个新的文//件,比如:log.txt、log1.txt......
org.apache.log4j.RollingFileAppender
//每天产生一个日志文件
org.apache.log4j.DailyRollingFileAppender
//将日志信息以流的形式发送到任意指定的地方
org.apache.log4j.WriterAppender


设置日志文件的布局

log4j.appender.A1.layout=org.apache.log4j.PatternLayout
//以HTML格式布局
org.apache.log4j.HTMLLayout
//可灵活指定布局模式
org.apache.log4j.PatternLayout
//简单的布局模式(包含日志信息的级别和字符串)
org.apache.log4j.SimpleLayout
//包含日志产生的时间、线程、类别等等信息
org.apache.log4j.TTCCLayout


设置输出样式

log4j.appender.A1.layout.ConversionPattern=%-d{yyyy-MM-dd HH:mm:ss} [%c]-[%p] %m%n
log4j采用类似C语法的格式化输出方式。

%m  输出代码中指定的消息
%p  输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL
%r  输出自应用启动到输出该log信息耗费的毫秒数
%c  输出所属的类目,通常就是所在类的全名
%t  输出产生该日志事件的线程名
%n  输出一个回车换行符,Windows平台为“\r\n”,Unix平台为“\n”
%d  输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyy MMM dd HH:mm:ss,SSS},输出类似:2006年8月8日 17:10:28,921
%l  输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数。比如本例为com.log4jdemo.Test


下面我们来看一下完整的配置文件:

log4j.rootLogger=ALL,A1,R
#=======定义appender为控制台=========#
log4j.appender.A1=org.apache.log4j.ConsoleAppender
log4j.appender.A1.layout=org.apache.log4j.PatternLayout
log4j.appender.A1.layout.ConversionPattern=[%l]-[%p] %m%n
#========定义appender为RollingFileAppender=========#
log4j.appender.R=org.apache.log4j.RollingFileAppender
log4j.appender.R.File=../logs/log.txt
log4j.appender.R.MaxFileSize=512KB
log4j.appender.R.MaxBackupIndex=1
log4j.appender.R.layout=org.apache.log4j.PatternLayout
log4j.appender.R.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} [%t] [%c] [%p] - %m%n


我们可以看到,这里定义了两个输出目的地,一个是控制台,另一个是生成一个日志并且当日志大小大于512KB的时候自动穿件一个新的备份日志。注意log4j.rootLogger=ALL,A1,R,这里可以选择如何将日志信息输出到什么地方,也就是说当项目不需要再向控制台输出的时候,我可以将rootLogger的A1去掉;如果当不需要输入或记录调试信息(debug)的时候,可以将All改为INFO,很方便吧?
做完这些,我们第一个Log4j的应用例子已经完成。

引用
http://blog.163.com/rui_uk/blog/static/2695963120073352040895/

猜你喜欢

转载自mikeching.iteye.com/blog/1714289