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

cra*_*abe 5 java logging slf4j mdc

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

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

为了清楚起见,如果我从头开始编写代码,我会这样做:

MDC.put();
try {
...
} finally {
  MDC.clear();
}
Run Code Online (Sandbox Code Playgroud)

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

Pav*_*mar 1

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