微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

将任意对象传递给Log4j中的ThreadContext.put

如何解决将任意对象传递给Log4j中的ThreadContext.put

我想像这样将任意对象传递给threadcontext.put()方法

MyObject originalMessage = new MyObject(...);
threadcontext.put("originalMessage",originalMessage);

但是该方法仅允许String作为其第二个参数:docs here

有没有办法在Log4j的MDC中将任意对象放入log4j?或对此的替代?我想要的是允许进一步执行log.error()自动记录originalMessage,而无需将其作为参数传递到任何地方。

此外,我无法自己调用toString(),因为我会急切地评估该方法(在该对象中非常繁重),所以我希望将其调用延迟到需要时才进行,就像您使用时一样将任意对象传递给log.debug("{}",someObject)

解决方法

我终于找到了{hack}解决方案herehere

代替它(不会编译):

ThreadContext.put("originalMessage",originalMessage);

我可以做到:

final var threadContextMap = (ObjectThreadContextMap) ThreadContext.getThreadContextMap();
threadContextMap.putValue("originalMessage",originalMessage);

只要您添加此JVM选项,此方法就起作用:

-Dlog4j2.threadContextMap=org.apache.logging.log4j.spi.CopyOnWriteSortedArrayThreadContextMap

现在,这看起来很骇人,因为getThreadContextMap()该方法应该返回内部地图的只读视图:

返回内部数据结构的只读视图,该内部数据结构用于存储线程上下文键值对...

因此,此解决方案正在投射只读地图,并且知道实现不是只读的,因此可以对其进行修改……不是最透明的解决方案,但它可以工作。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?