Log4J的多日志文件配置:
一.rootLogger只配置warn级别及以上的错误,另外定义的两个独立的日志文件,记录低级别的日志。
1.首先定义rootLogger的level为:warn,如下:
log4j.rootLogger=warn,Console,R
#console
log4j.appender.Console=org.apache.log4j.ConsoleAppender
log4j.appender.Console.layout=org.apache.log4j.PatternLayout
log4j.appender.Console.layout.ConversionPattern=CTM - %d{yyyy-MM-dd HH\:mm\:ss} %5p [%c{1}]\:%L - %m%n
#log4j.appender.Console.layout.ConversionPattern=CurrentTimeMonitor - %d{yy-MM-dd HH\:mm\:ss} %5p %c{1} [%t]\:%L - %m%n
#file
log4j.appender.R=org.apache.log4j.RollingFileAppender
#log4j.appender.R.File=${catalina.home}/logs/tomcat.log
log4j.appender.R.File=${webApp.root}/WEB-INF/logs/app.log
log4j.appender.R.MaxFileSize=10MB
log4j.appender.R.MaxBackupIndex=2
log4j.appender.R.layout=org.apache.log4j.PatternLayout
log4j.appender.R.layout.ConversionPattern=CTM - %d{yyyy-MM-dd HH\:mm\:ss} %5p [%c{1}]\:%L - %m%n
其中${webApp.root}/,是配置在web,xml中的JVM变量:
<!--log4j -->
<context-param>
<param-name>webAppRootKey</param-name>
<param-value>webApp.root</param-value>
</context-param>
<context-param>
<param-name>log4jConfigLocation</param-name>
<param-value>classpath:log4j.properties</param-value>
</context-param>
<context-param>
<param-name>log4jRefreshInterval</param-name>
<param-value>6000</param-value>
</context-param>
<!--log4j Listener -->
<listener>
<listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
</listener>
2.定义其余两个日志文件:
# in one class has more than one logger;
log4j.logger.myTest1=info, test1,Console
log4j.additivity.myTest1 = false
log4j.appender.test1=org.apache.log4j.DailyRollingFileAppender
log4j.appender.test1.File=${webApp.root}/WEB-INF/logs/test1.log
log4j.appender.test1.layout=org.apache.log4j.PatternLayout
log4j.appender.test1.layout.ConversionPattern=CTM - %d{yyyy-MM-dd HH\:mm\:ss} %5p [%c{1}]\:%L - %m%n
log4j.logger.myTest2=info, test2
log4j.additivity.myTest2 = false
log4j.appender.test2=org.apache.log4j.FileAppender
log4j.appender.test2.File=${webApp.root}/WEB-INF/logs/test2.log
log4j.appender.test2.layout=org.apache.log4j.PatternLayout
log4j.appender.test2.layout.ConversionPattern=CTM - %d{yyyy-MM-dd HH\:mm\:ss} %5p [%c{1}]\:%L - %m%n
注:
(1)log4j.additivity.myTest1 = false,这句话定义,可以避免该日志文件的输出到默认的log4j.rootLogger所配置的
日志中的;否则,即使rootLogger设置为:warn,仍然会把myTest1的info信息写入到rootLogger里面的;
(2)如果仍然想把myTest1的内容输出到其他地方如:'Console',就要由原先的log4j.logger.myTest1=info, test1,
修改成:log4j.logger.myTest1=info, test1,Console。