ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

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

2019-10-26 04:01:09  阅读:193  来源: 互联网

标签:logging log4j2 tostring slf4j java


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

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

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

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

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

解决方法:

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

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

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

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

标签:logging,log4j2,tostring,slf4j,java
来源: https://codeday.me/bug/20191026/1933832.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有