李锋镝的博客

  • 首页
  • 时间轴
  • 留言
  • 插件
  • 左邻右舍
  • 关于我
    • 关于我
    • 另一个网站
  • 知识库
  • 赞助
Destiny
自是人生长恨水长东
  1. 首页
  2. 原创
  3. 正文

MDC介绍

2025年3月7日 208点热度 0人点赞 0条评论

MDC(Mapped Diagnostic Context,映射诊断上下文)是一种在日志记录中用于传递和管理上下文信息的工具,在Java的日志框架中广泛应用,如Log4j、Logback等。以下是关于MDC的详细介绍:

基本概念

MDC是一个与当前执行线程绑定的上下文对象,它允许开发者在应用程序的不同部分(例如不同的方法、不同的类)中设置和获取与当前操作相关的上下文信息。这些信息可以包括用户ID、请求ID、事务ID、操作时间等,并且会随着日志记录一起输出,有助于在复杂的分布式系统或多线程环境中跟踪和诊断问题。

工作原理

  • 存储数据:MDC本质上是一个基于线程的本地存储(Thread Local Storage)。当一个线程在执行过程中向MDC中放入数据时,这些数据会与该线程绑定。例如,在处理一个HTTP请求的线程中设置了请求ID到MDC,那么这个请求ID就会与该线程关联起来。
  • 日志关联:在日志记录过程中,日志框架会从当前线程的MDC中获取相关信息,并将其添加到日志消息中。这样,每条日志都会包含与之相关的上下文信息,方便开发人员在查看日志时能够快速定位问题所在的请求或操作。

主要作用

  • 请求跟踪:在分布式系统中,一个请求可能会经过多个服务或模块,通过在每个服务中设置和传递相同的请求ID到MDC,开发人员可以在不同服务的日志中快速找到与该请求相关的所有记录,从而更好地理解请求的处理流程和排查问题。
  • 多线程区分:在多线程应用程序中,不同线程可能会执行相同的代码逻辑,但需要区分不同线程的操作。MDC可以为每个线程设置独特的上下文信息,使得日志能够清晰地显示每个线程的执行情况。
  • 业务信息记录:可以将一些重要的业务信息(如用户ID、订单ID等)放入MDC,以便在日志中快速了解与业务操作相关的信息,有助于进行业务分析和问题定位。

使用示例(以Logback为例)

  • 添加依赖
    在Maven项目中,需要添加Logback的相关依赖:

    <dependency>
    <groupId>ch.qos.logback</groupId>
    <artifactId>logback-classic</artifactId>
    <version>1.2.3</version>
    </dependency>
  • 代码中使用

    import ch.qos.logback.classic.Logger;
    import org.slf4j.LoggerFactory;
    import org.slf4j.MDC;
    public class MDCExample {
    public static void main(String[] args) {
        // 设置MDC中的信息
        MDC.put("requestId", "123456");
        MDC.put("userId", "user001");
    
        Logger logger = (Logger) LoggerFactory.getLogger(MDCExample.class);
        logger.info("This is an info message.");
    
        // 清除MDC中的信息
        MDC.clear();
    }
    }
  • 配置文件设置
    在 logback.xml 配置文件中,可以通过 %X{key} 的形式来输出MDC中的信息:

    <configuration>
    <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
        <encoder>
            <pattern>%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{36} [%X{requestId}] [%X{userId}] - %msg%n</pattern>
        </encoder>
    </appender>
    
    <root level="info">
        <appender-ref ref="CONSOLE" />
    </root>
    </configuration>
除非注明,否则均为李锋镝的博客原创文章,转载必须以链接形式标明本文链接

本文链接:https://www.lifengdi.com/archives/article/4230

相关文章

  • Linux服务器查看日志命令总结1
  • 关闭apache httpclient4.5 DEBUG日志
  • SpringBoot常用注解
  • CompletableFuture使用详解
  • 金融级JVM深度调优实战的经验和技巧
本作品采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可
标签: MDC 日志
最后更新:2025年3月7日

李锋镝

既然选择了远方,便只顾风雨兼程。

打赏 点赞
< 上一篇
下一篇 >

文章评论

1 2 3 4 5 6 7 8 9 11 12 13 14 15 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 46 47 48 49 50 51 52 53 54 55 57 58 60 61 62 63 64 65 66 67 69 72 74 76 77 78 79 80 81 82 85 86 87 90 92 93 94 95 96 97 98 99
取消回复

我有一瓢酒,可以慰风尘。

最新 热点 随机
最新 热点 随机
SpringBoot框架自动配置之spring.factories和AutoConfiguration.imports 应用型负载均衡(ALB)和网络型负载均衡(NLB)区别 什么是Helm? TransmittableThreadLocal介绍与使用 ReentrantLock深度解析 RedisTemplate和Redisson的区别
玩博客的人是不是越来越少了?准备入手个亚太的ECS,友友们有什么建议吗?什么是Helm?2024年11月1号 农历十月初一别再背线程池的七大参数了,现在面试官都这么问URL地址末尾加不加“/”有什么区别
更多的Xshell配色方案 忽然发现,在校大学生可以免费领一年有道云笔记会员~ IntelliJ IDEA 2020.3.x永久白嫖(Windows/Mac) 程序员的自我修养 JAVA技术点总结一 Elasticsearch:cat API 介绍及其使用
标签聚合
设计模式 MySQL Redis SQL docker 架构 JVM 面试 教程 多线程 Spring 日常 分布式 SpringBoot K8s 文学 ElasticSearch 数据库 IDEA JAVA
友情链接
  • i架构
  • 临窗旋墨
  • 博友圈
  • 博客录
  • 博客星球
  • 哥斯拉
  • 志文工作室
  • 搬砖日记
  • 旋律的博客
  • 旧时繁华
  • 林羽凡
  • 知向前端
  • 蜗牛工作室
  • 集博栈
  • 韩小韩博客
  • 風の声音

COPYRIGHT © 2025 lifengdi.com. ALL RIGHTS RESERVED.

Theme Kratos Made By Dylan

津ICP备2024022503号-3