关于LOG4J 按照级别输出日志,并按照级别输出到不同文件中的说法有很多, 网上贴的最多的log4j.properties的设置是这样的

log4j.rootLogger=info,stdout,info,debug,error
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=[%-5p] [%d{HH:mm:ss}] %c - %m%n log4j.logger.info=info
log4j.appender.info=org.apache.log4j.DailyRollingFileAppender
log4j.appender.info.layout=org.apache.log4j.PatternLayout
log4j.appender.info.layout.ConversionPattern=[%-5p] [%d{HH:mm:ss}] %c - %m%n
log4j.appender.info.datePattern='.'yyyy-MM-dd
log4j.appender.info.Threshold = INFO
log4j.appender.info.append=true
log4j.appender.info.File=${webApp.root}/WEB-INF/logs/info.log log4j.logger.debug=debug
log4j.appender.debug=org.apache.log4j.DailyRollingFileAppender
log4j.appender.debug.layout=org.apache.log4j.PatternLayout
log4j.appender.debug.layout.ConversionPattern=[%-5p] [%d{HH:mm:ss}] %c - %m%n
log4j.appender.debug.datePattern='.'yyyy-MM-dd
log4j.appender.debug.Threshold = DEBUG
log4j.appender.debug.append=true
log4j.appender.debug.File=${webApp.root}/WEB-INF/logs/debug.log log4j.logger.error=error
log4j.appender.error=org.apache.log4j.DailyRollingFileAppender
log4j.appender.error.layout=org.apache.log4j.PatternLayout
log4j.appender.error.layout.ConversionPattern=[%-5p] [%d{HH:mm:ss}] %c - %m%n
log4j.appender.error.datePattern='.'yyyy-MM-dd
log4j.appender.error.Threshold = ERROR
log4j.appender.error.append=true
log4j.appender.error.File=${webApp.root}/WEB-INF/logs/error.log

而实际上这部分代码解决不了按照LOG4J的级别文件进行文件输出。

配置中关键的配置说明是这一句:

log4j.appender.debug.Threshold = INFO

而它的作用是输出INFO级别以上的内容到${webApp.root}/WEB-INF/logs/info.log中,所以info.log文件中包含了ERROR级别的文件。

正确的解法是:

定义自己的Appender类,继承DailyRollingFileAppender,改写针对Threshold 的设置说明。

源代码记载:

public boolean isAsSevereAsThreshold(Priority priority){
return threshold == null || priority.isGreaterOrEqual(threshold);
}

重写 isAsSevereAsThreshold(Priority priority)方法

public class LogAppender extends DailyRollingFileAppender {

 @Override
public boolean isAsSevereAsThreshold(Priority priority) {
//只判断是否相等,而不判断优先级
return this.getThreshold().equals(priority);
}
}

这样,进行唯一判断,只有当Threshold与priority一致时,才进行输出,就实现了真正Log4j按照级别输出日志文件。

在log4j.properties中,将配置文件作如下修改:

log4j.logger.info=info
log4j.appender.info=com.company.LogAppender
log4j.appender.info.layout=org.apache.log4j.PatternLayout
log4j.appender.info.layout.ConversionPattern=[%-5p] [%d{HH:mm:ss}] %c - %m%n
log4j.appender.info.datePattern='.'yyyy-MM-dd
log4j.appender.info.Threshold = INFO
log4j.appender.info.append=true
log4j.appender.info.File=${webApp.root}/WEB-INF/logs/info.log

到此,即完成了按照Log4j按照日志级别输出到不同文件中的功能。

原文:http://blog.csdn.net/projava/article/details/7344839

最新文章

  1. JavaScript之Array类型
  2. 如何得到自定义UITableViewCell中的按钮所在的cell的indexPath.row
  3. Xcode导航栏不显示模拟器选择框ToolBar
  4. 基于canvas实现物理运动效果与动画效果(一)
  5. javascript跨域通信(二):window.name实现的跨域数据传输
  6. Sqlserver_判断该路径是否存在该文件
  7. linux下动态链接库.so文件 静态链接库.a文件创建及使用
  8. ruby on rails 实战(一)
  9. pyQt 每日一练习 -- 登录框
  10. work2
  11. scrapy爬虫初体验
  12. STL中vector的赋值,遍历,查找,删除,自定义排序——sort,push_back,find,erase
  13. 玩转Web之servlet(一)---怎样创建一个servlet
  14. linux守护进程、SIGHUP与nohup详解
  15. docker创建ceph集群
  16. 深入理解 Python 中的上下文管理器
  17. 容易被误读的IOSTAT
  18. Javascript高级编程学习笔记(37)—— DOM(3)Element
  19. Go语言第一深坑:interface 与 nil 的比较
  20. 【QT】打开文件对话框,选择路径下文件

热门文章

  1. 容器计划任务大坑:在alpine容器里,想用非root帐号执行crontab任务
  2. centos7.x firewall简单使用
  3. React + Reflux 渲染性能优化原理
  4. 使用scss + react + webpack + es6实现幻灯片
  5. js 格式化时间,可定义格式
  6. bzoj 1925 dp
  7. 在Tomcat中部署web项目的三种方式
  8. 理解事件(Event)
  9. iOS 11开发教程(一)
  10. python调用matlab