LOG4J的多日志配置

 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。

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值