zoukankan      html  css  js  c++  java
  • 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

  • 相关阅读:
    InnoDB引擎面面观
    [读史思考]为何此大神可以同时进入文庙和武庙?
    [源码解析] 当 Java Stream 遇见 Flink
    Alink漫谈(十八) :源码解析 之 多列字符串编码MultiStringIndexer
    [源码解析] Flink UDAF 背后做了什么
    [业界方案] ClickHouse业界解决方案学习笔记
    Istio Routing 实践掌握virtualservice/gateway/destinationrule/AB版本发布/金丝雀发布
    树立个人品牌意识:从背景调查谈谈职业口碑的重要性
    Istio 生产环境用户流量接入方案
    故障管理:故障应急和故障复盘
  • 原文地址:https://www.cnblogs.com/azhqiang/p/5364303.html
Copyright © 2011-2022 走看看