• Log4j按级别输出日志到不同文件配置分析


    关于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

  • 相关阅读:
    css的继承问题
    js弹出层
    实现网页弹出框后背景不能滑动的效果
    vue的爬坑之路(四)之基于vuecli 动态添加iconfont的symbol方法
    vue的爬坑之路(五)之基于vuecli li列表的显示隐藏
    自定义复选框checkbox样式
    vue的爬坑之路(三)之基于vuecli的VueAwesomeSwiper轮播滑块插件的使用及常见问题
    iOS 开发学习总结
    (转载)iOS股票k线组件源码,支持其他图表类型
    iOS Objective C Memory management
  • 原文地址:https://www.cnblogs.com/azhqiang/p/5364303.html
Copyright © 2020-2023  润新知