Empty Threadcontext支持log4j2

时间:2017-01-10 12:28:30

标签: java stack log4j2 threadcontext

我正在尝试迁移到log4j2。 在RollingFile Appender中,我添加如下:

<PatternLayout>
    <pattern>[%d{MM/dd/yy HH:mm:ss:SSS z}] %-18.18t %-35.35c{1} %-5p (%F:%L) %m \t %x %n</pattern>
</PatternLayout>

我们知道%x用于将堆栈元素打印到每个记录器语句的末尾。

现在如果我的筹码最初是空的,它会给我空的大括号,如下所示。

[01/10/17 12:17:37:116 IST] main               Example2                            WARN  (Example2.java:52) 10 is the number     [] 

[01/10/17 12:17:37:116 IST]主要示例2 WARN(Example2.java:52)10是数字[]

那么我该如何处理这个空堆栈场景?

1 个答案:

答案 0 :(得分:2)

您可以使用PatternLayoutnotEmpty{pattern}模式转换器:

当且仅当模式中的所有变量都不为空时,才输出评估模式的结果。

例如:

%notEmpty{[%x]}

别名:variablesNotEmpty {pattern}, varsNotEmpty {图案} notEmpty {pattern}