发布时间: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中指定的键值对
Hive新增/变更字段后,Hive metastore与Hive tblproperties缓存的spark schema不一致处理
[创业] 读书推荐:创业者必读的《Founders at work: Stories of Startups' Early Days》
微软已发出提醒:2023年后将不再支持Windows 8.1
STC8H开发(十四): I2C驱动RX8025T高精度实时时钟芯片
(Windbg调试二)C++ delete指针后依然可以访问的问题
菏泽学院计算机学院康鸿雁,菏泽学院在山东省大学生软件设计大赛中获佳绩
istio 服务网格_如何在Kubernetes上使用Istio服务网格设置JHipster微服务