log4j输出多个自定义日志文件

导入包

commons-logging-1.1.1.jar
log4j-1.2.16.jar


如果在实际应用中需要输出独立的日志文件,怎样才能把所需的内容从原有日志中分离,形成单独的日志文件呢?

先看一个常见的log4j.properties文件,它是在控制台和test.log文件中记录日志: 

复制代码
 1 log4j.rootLogger=DEBUG, stdout, logfile  
 4 
 5 log4j.appender.stdout=org.apache.log4j.ConsoleAppender 
 7 log4j.appender.stdout.layout=org.apache.log4j.PatternLayout 
 9 log4j.appender.stdout.layout.ConversionPattern=%d %p [%c] - %m%n  
12 
13 log4j.appender.logfile=org.apache.log4j.RollingFileAppender
15 log4j.appender.logfile.File=log/test.log
17 log4j.appender.logfile.MaxFileSize=128MB
19 log4j.appender.logfile.MaxBackupIndex=3
21 log4j.appender.logfile.layout=org.apache.log4j.PatternLayout
23 log4j.appender.logfile.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p [%t] %c.%M(%L) - %m%n
复制代码

 

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

  如果在同一类中需要输出多个日志文件呢?其实道理是一样的,先在Test.java中定义:

private static Log logger1 = LogFactory.getLog("mylogger1");

private static Log logger2 = LogFactory.getLog("mylogger2");

  log4j.properties中配置如下:

复制代码
 1 log4j.logger.mylogger1=DEBUG,test1
 2 log4j.appender.test1=org.apache.log4j.FileAppender
 3 log4j.appender.test1.File=log/test1.log
 4 log4j.appender.test1.layout=org.apache.log4j.PatternLayout
 5 log4j.appender.test1.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p [%t] %c.%M(%L) - %m%n 
 6 
 7 log4j.logger.mylogger2=DEBUG,test2
 8 log4j.appender.test2=org.apache.log4j.FileAppender
 9 log4j.appender.test2.File=log/test2.log
10 log4j.appender.test2.layout=org.apache.log4j.PatternLayout
11 log4j.appender.test2.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p [%t] %c.%M(%L) - %m%n
复制代码

 

不同日志要使用不同的logger(如输出到test1.log的要用logger1.info("abc"))。

还有一个问题,就是这些自定义的日志默认是同时输出到log4j.rootLogger所配置的日志中的,如何能只让它们输出到自己指定的日志中呢?别急,这里有个开关:

log4j.additivity. mylogger1 = false

它用来设置是否同时输出到log4j.rootLogger所配置的日志中,设为false就不会输出到其它地方了。

但是这种方式有个小缺陷,那就是打印的日志中类名只能是mylogger或者mylogger2。

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值