政府网站建设程序合肥网站设计
MDC 分布式日志调用日志系统-OnlineDebug
1、背景
在分布式系统中,在排查线上问题的时候我们希望可以通过请求的唯一ID(或者用户Id等),打印整个请求在多个系统中的全链路,帮助我们提升问题排查能力。
下面事我梳理的几个需求点:
1:可以通过动态配置userId,来全链路开启该userId的全链路日志。
2:在多线程池执行任务下,切换线程,也可以打印debug日志。
3:duboo调用其他服务,这个动态中的userId可以传递。
1:log4j2的MDC的能力
2:Dubbo的RpcContext
3:基于dubbo的filte+SPI机制实现接口自动传递userId
4:基于apollo动态配置需要打印的uerId的日志信息。
整个流程:
MDC说明
MDC(Mapped Diagnostic Context,映射调试上下文)是 log4j 、logback及log4j2 提供的一种方便在多线程条件下记录日志的功能。MDC 可以看成是一个与当前线程绑定的哈希表,可以往其中添加键值对。MDC 中包含的内容可以被同一线程中执行的代码所访问。
当前线程的子线程会继承其父线程中的 MDC 的内容。当需要记录日志时,只需要从 MDC 中获取所需的信息即可。MDC 的内容则由程序在适当的时候保存进去。对于一个 Web 应用来说,通常是在请求被处理的最开始保存这些数据。
异步线程的UserId的传递
todo
dubbo的UserId的传递
todo