Log4j支持两种格式的配置文件:xml和properties;依赖commons-logging包apache
1、配置根loggerapp
log4j.rootLogger=[level],appenderName,appenderName,......布局
level可分为OFF、 FATAL、ERROR、WARN、INFO、DEBUG、ALL,若是配置OFF则不打出任何信息,优先级为:error>warn>info>debug,不区分大小写spa
可添加子类,例:线程
log4j.category.org.nutz=INFO, console, nutzdebug
log4j.category.com.gtz=DEBUG, console, gtz日志
二、配置日志信息输出地Appenderxml
log4j.appender.appenderName = fully.qualified.name.of.appender.class事件
log4j.appender.appenderName.option1 = value1字符串
…
log4j.appender.appenderName.optionN = valueN
输出形式有4中:
org.apache.log4j.ConsoleAppender(控制台)
org.apache.log4j.FileAppender(文件)
org.apache.log4j.DailyRollingFileAppender(天天产生一个日志文件)
org.apache.log4j.RollingFileAppender(文件大小到达指定尺寸的时候产生一个新的文件)
可经过 log4j.appender.appenderName.MaxFileSize=100KB设置文件大小
还可经过 log4j.appender.appenderName.MaxBackupIndex=1设置为保存一个备份文件。
org.apache.log4j.WriterAppender(将日志信息以流格式发送到任意指定的地方)
三、配置日志信息的格式(布局)Layout
Layout 负责格式化Appender的输出,语法为:
log4j.appender.appenderName.layout = fully.qualified.name.of.layout.class
log4j.appender.appenderName.layout.option1 = value1
…
log4j.appender.appenderName.layout.optionN = valueN
其中,Log4j提供的layout有如下几种:
org.apache.log4j.HTMLLayout(以HTML表格形式布局)
org.apache.log4j.PatternLayout(能够灵活地指定布局模式)
org.apache.log4j.SimpleLayout(包含日志信息的级别和信息字符串)
org.apache.log4j.TTCCLayout(包含日志产生的时间、线程、类别等等信息)
四、格式化日志信息
log4j.appender.appenderName.layout.ConversionPattern=%d [%t] %-5p %c - %m%n
%m 输出代码中指定的消息
%p 输出优先级,即DEBUG,INFO,WARN,ERROR,FATAL
%r 输出自应用启动到输出该log信息耗费的毫秒数
%c 输出所属的类目,一般就是所在类的全名
%t 输出产生该日志事件的线程名
%n 输出一个回车换行符,Windows平台为“rn”,Unix平台为“n”
%d 输出日志时间点的日期或时间,默认格式为ISO8601,也能够在其后指定格式,好比:%d{yyyy MMM dd HH:mm:ss,SSS},输出相似:2002年10月18日 22:10:28,921
%l 输出日志事件的发生位置,包括类目名、发生的线程,以及在代码中的行数。
Logger类:完成日志记录,设置日志信息级别
Appender类:决定日志去向,终端、DB、硬盘
Layout类:决定日志输出的样式,例如包含当前线程、行号、时间
实例:
log4j.rootCategory=INFO, stdout , R
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern= %p [%t] %C.%M(%L) | %m%n
log4j.appender.R=org.apache.log4j.DailyRollingFileAppender
log4j.appender.R.layout=org.apache.log4j.PatternLayout
log4j.appender.R.File=D:\Tomcat 5.5\logs\test.log
log4j.appender.R.layout.ConversionPattern=%d %p %t %c - %m%n