Log4j分级别记录日志文件
在记录日志的时候通常我们都希望不同级别的日志能够分别记录在不同的日志文件中,然后有一个汇总的日志文件记录所有的日志信息,因为在大多数情况下我们可能只会关注那些Error级别的日志信息。利用log4j去记录这些信息是比较简单的,我们可以配置多个不同的appender,然后每个appender对应的threshold指定需要过滤的不同级别。Appender的threshold属性默认是为空的,即表示不过滤掉任何级别的日志信息,也就是记录所有级别的日志信息。该属性值如果设为ERROR,则表示只记录ERROR级别以上的日志信息,对于ERROR以下级别的日志信息,如DEBUG、INFO等将会忽略。所以如果我们需要按照日志信息级别的不同记录不同的日志文件,我们可以这样设置log4j.properties文件。
#指定默认情况下的日志输出级别为INFO,对应的appender为stdout、info、warn、error和fatal
log4j.rootLogger=INFO,stdout,info,warn,error,fatal
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d{yyyy-MM-ddHH\:mm\:ss,SSS}[%p]\=\=\=\=%t\:%c.%M(%L)\r\n\t%m%n\r\n
log4j.appender.info=org.apache.log4j.DailyRollingFileAppender
log4j.appender.info.layout=org.apache.log4j.PatternLayout
log4j.appender.info.layout.ConversionPattern=%d{yyyy-MM-ddHH\:mm\:ss,SSS}[%p]\=\=\=\=%t\:%c.%M(%L)\r\n\t%m%n\r\n
log4j.appender.info.threshold=INFO
log4j.appender.info.Encoding=UTF-8
log4j.appender.info.File=app.info.log
log4j.appender.warn=org.apache.log4j.DailyRollingFileAppender
log4j.appender.warn.layout=org.apache.log4j.PatternLayout
log4j.appender.warn.layout.ConversionPattern=%d{yyyy-MM-ddHH\:mm\:ss,SSS}[%p]\=\=\=\=%t\:%c.%M(%L)\r\n\t%m%n\r\n
log4j.appender.warn.threshold=WARN
log4j.appender.warn.Encoding=UTF-8
log4j.appender.warn.File=app.warn.log
log4j.appender.error=org.apache.log4j.DailyRollingFileAppender
log4j.appender.error.layout=org.apache.log4j.PatternLayout
log4j.appender.error.layout.ConversionPattern=%d{yyyy-MM-ddHH\:mm\:ss,SSS}[%p]\=\=\=\=%t\:%c.%M(%L)\r\n\t%m%n\r\n
log4j.appender.error.threshold=ERROR
log4j.appender.error.Encoding=UTF-8
log4j.appender.error.File=app.error.log
log4j.appender.fatal=org.apache.log4j.DailyRollingFileAppender
log4j.appender.fatal.layout=org.apache.log4j.PatternLayout
log4j.appender.fatal.layout.ConversionPattern=%d{yyyy-MM-ddHH\:mm\:ss,SSS}[%p]\=\=\=\=%t\:%c.%M(%L)\r\n\t%m%n\r\n
log4j.appender.fatal.threshold=FATAL
log4j.appender.fatal.Encoding=UTF-8
log4j.appender.fatal.File=app.fatal.log
在上述配置中log4j.rootLogger是用来指定默认情况下的日志输出级别以及对应的appender的,其值是类似这样的格式:
<日志输出级别>,<appender1>[,appender2[,append3…]]
Appender中如果指定了对应的日志输出级别则会覆盖rootLogger的配置。像上面的配置对于info那个appender其日志输出级别就是info,哪怕rootLogger的默认日志输出级别改为ERROR,名称为info的appender仍然会记录INFO级别的日志信息。
如果我们希望将com.app.package包下面的所有INFO级别以上的日志都记录在app.package.log文件中,那么我们就可以这样来配置。
log4j.logger.com.app.package=INFO,test
log4j.appender.test=org.apache.log4j.DailyRollingFileAppender
log4j.appender.test.layout=org.apache.log4j.PatternLayout
log4j.appender.test.layout.ConversionPattern=%d{yyyy-MM-ddHH\:mm\:ss,SSS}[%p]\=\=\=\=%t\:%c.%M(%L)\r\n\t%m%n\r\n
log4j.appender.test.Encoding=UTF-8
log4j.appender.test.File=app.package.log
(注:本文是基于log4j1.2.17所写)