gpt4 book ai didi

java - 在处理开始时而不是在结束时调用 MDC.clear() 有什么缺点吗?

转载 作者:行者123 更新时间:2023-12-02 11:16:46 25 4
gpt4 key购买 nike

我喜欢在我的应用程序中使用 MDC 日志记录字段,因为它使查找所有相关日志行变得更加容易。我还发现在处理开始时清除 MDC 上下文要容易得多,因为我知道应用程序的入口点在哪里,但有许多可能的异常路径,我自己或其他开发人员可能忘记调用 MDC.clear( )。

所以我的问题是,我这样做有什么缺点吗?根据经验,始终在处理开始与结束时清除上下文。

要明确的是,如果我从头开始编写代码,我会这样做:

MDC.put();
try {
...
} finally {
MDC.clear();
}

但有时我必须使用基类或库中没有任何 MDC 相关代码的内容,因此我按照我所描述的方式进行操作,因为我不想从库中复制基类只需添加几行 MDC 代码...

最佳答案

建议对此保持谨慎。如果您指的是应用程序的开始,那么它没有任何意义,并且 MDC 当时不会有任何内容。我猜您的引用位于请求的开头,但在这种情况下,如果您这样做,可能会并行处理其他请求,并且清除 MDC 会影响所有其他请求的记录。您可以在每个请求结束时调用MDC.remove()。在不知道您的确切应用程序的情况下,这就是我所能建议的。

关于java - 在处理开始时而不是在结束时调用 MDC.clear() 有什么缺点吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42159379/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com