发布时间:2024-04-09 15:01
之前有一篇文章简单的介绍过MDC,这次结合具体的案例、生产中的具体问题深入了解一下MDC。
1、简介:
MDC(Mapped Diagnostic Context,映射调试上下文)是 log4j 、logback及log4j2 提供的一种方便在多线程条件下记录日志的功能。MDC 可以看成是一个与当前线程绑定的哈希表,可以往其中添加键值对。MDC 中包含的内容可以被同一线程中执行的代码所访问。
当前线程的子线程会继承其父线程中的 MDC 的内容。当需要记录日志时,只需要从 MDC 中获取所需的信息即可。MDC 的内容则由程序在适当的时候保存进去。对于一个 Web 应用来说,通常是在请求被处理的最开始保存这些数据
2、API说明:
clear()
:移除所有MDC
get (String key)
:获取当前线程MDC中指定key的值
getContext()
:获取当前线程MDC的MDC
put(String key, Object o)
:往当前线程的MDC中存入指定的键值对
remove(String key)
:删除当前线程MDC中指定的键值对