美文网首页
Log4j 配置日志打印格式

Log4j 配置日志打印格式

作者: 半支铅笔半块橡皮 | 来源:发表于2019-10-29 17:36 被阅读0次

    最近在看Dubbo的源码发现其默认的日志格式没有打印方法名行号,参考了一些资料和源码,问题解决了,顺便把一些常用log4j日志输出格式记录如下:

    常见Pattern配置格式

    c:category的名称,可使用{n}限制输出的精度。例如:logger名为"a.b.c",%c{2}将输出"b.c"。

    C:产生log事件的java完全限定类名。可使用{n}限制输出的精度。例如:“org.apache.xyz.SomeClass”,%C{2}将输出“SomeClass”。

    d:时间和日期的输出格式,例如:%d{yyyy MM dd HH:mm:ss,SS},可不带后面的日期格式字符。

    F:产生log事件的java源文件名,带“.java”后缀及包名称。

    l:log发生位置的详细描述,包括方法名、文件名及行号。

    L:log发生在源文件中的位置。

    m:log事件的消息内容。

    M:log发生时所在的方法名称。

    n:根据所运行的平台输出相应的行分隔字符。

    p:log事件的级别。

    r:自程序运行至log事件产生所经过的时间。

    t: 产生log的线程名称。

    看了上面的格式说明,我在原来的格式上面加上{%l} ,如下:
    [%d{dd/MM/yy HH:mm:ss:SSS z}] %t %5p {%l} %c{2}: %m%n
    就可以打印FullLocation,也就是全类名,方法,行号这些详细信息

    源码中找实现

    对于上面这些配置的实现,我在源码PatternParser类中找到了相应的处理,比如可以参看FullLocationPatternConverterformat,来参考log4j 如何实现打印类名和行号的。

    //org.apache.log4j.pattern.PatternParser
      static {
        // We set the global rules in the static initializer of PatternParser class
        Map rules = new HashMap(17);
        rules.put("c", LoggerPatternConverter.class);
        rules.put("logger", LoggerPatternConverter.class);
    
        rules.put("C", ClassNamePatternConverter.class);
        rules.put("class", ClassNamePatternConverter.class);
    
        rules.put("d", DatePatternConverter.class);
        rules.put("date", DatePatternConverter.class);
    
        rules.put("F", FileLocationPatternConverter.class);
        rules.put("file", FileLocationPatternConverter.class);
    
        rules.put("l", FullLocationPatternConverter.class);
    
        rules.put("L", LineLocationPatternConverter.class);
        rules.put("line", LineLocationPatternConverter.class);
    
        rules.put("m", MessagePatternConverter.class);
        rules.put("message", MessagePatternConverter.class);
    
        rules.put("n", LineSeparatorPatternConverter.class);
    
        rules.put("M", MethodLocationPatternConverter.class);
        rules.put("method", MethodLocationPatternConverter.class);
    
        rules.put("p", LevelPatternConverter.class);
        rules.put("level", LevelPatternConverter.class);
    
        rules.put("r", RelativeTimePatternConverter.class);
        rules.put("relative", RelativeTimePatternConverter.class);
    
        rules.put("t", ThreadPatternConverter.class);
        rules.put("thread", ThreadPatternConverter.class);
    
        rules.put("x", NDCPatternConverter.class);
        rules.put("ndc", NDCPatternConverter.class);
    
        rules.put("X", PropertiesPatternConverter.class);
        rules.put("properties", PropertiesPatternConverter.class);
    
        rules.put("sn", SequenceNumberPatternConverter.class);
        rules.put("sequenceNumber", SequenceNumberPatternConverter.class);
    
        rules.put("throwable", ThrowableInformationPatternConverter.class);
        PATTERN_LAYOUT_RULES = new ReadOnlyMap(rules);
    
        Map fnameRules = new HashMap(4);
        fnameRules.put("d", FileDatePatternConverter.class);
        fnameRules.put("date", FileDatePatternConverter.class);
        fnameRules.put("i", IntegerPatternConverter.class);
        fnameRules.put("index", IntegerPatternConverter.class);
    
        FILENAME_PATTERN_RULES = new ReadOnlyMap(fnameRules);
      }
    

    相关文章

      网友评论

          本文标题:Log4j 配置日志打印格式

          本文链接:https://www.haomeiwen.com/subject/zlsgvctx.html