slf4j-log4j在将对象传递给Asynchronus记录器之前将其转换为字符串

Vid*_*nan 3 java logging tostring slf4j log4j2

我希望记录请求和对Web服务的响应。我将slf4j与底层log4j2实现一起使用。我的记录器语句如下所示。

LOGGER.info(“ {}”,新的CustomObject(request,response,param1,param2));

我已经在所有必需的对象和CustomObject类中实现了toString方法,以记录该对象的所有属性。

我看到CustomObject的toString方法在将日志消息传递给Asynch记录器之前被调用。

无论如何,在实际日志记录发生时,是否将自定义对象的序列化/ toString方法调用推迟到?

Rem*_*pma 5

这是设计使然:如果记录了一个对象,则有可能在后台线程可以记录该对象之前对其进行了更改,并且最终会得到与您想要的不同的日志条目。

在您的示例中,您的应用程序不包含对CustomObject的引用,因此无法更改,但Log4j2无法知道,因此采用了保守的方法。

有一个系统属性可以将其关闭,但是使用它意味着所有记录的对象必须有效地不可变,否则您会发现您的日志在骗您……(我也不是100%肯定该系统属性仍然有效,因为Log4j2在2.6版中变得无垃圾。)

更新(2017-12-09):系统属性在2.6版之后的版本中仍然有效。(但我不建议您在后台线程中渲染消息,除非您非常有信心应用程序不会修改已记录的对象。)