最近在看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
类中找到了相应的处理,比如可以参看FullLocationPatternConverter
的 format
,来参考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);
}