分布式系统debug日志链路日志-OnlineDebug

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的日志信息。

整个流程:

分布式系统debug日志链路日志-OnlineDebug_第1张图片

MDC说明

MDC(Mapped Diagnostic Context,映射调试上下文)是 log4jlogbacklog4j2 提供的一种方便在多线程条件下记录日志的功能。MDC 可以看成是一个与当前线程绑定的哈希表,可以往其中添加键值对。MDC 中包含的内容可以被同一线程中执行的代码所访问

当前线程的子线程会继承其父线程中的 MDC 的内容。当需要记录日志时,只需要从 MDC 中获取所需的信息即可。MDC 的内容则由程序在适当的时候保存进去。对于一个 Web 应用来说,通常是在请求被处理的最开始保存这些数据。

异步线程的UserId的传递

todo

dubbo的UserId的传递

todo

dubbo的SPI+filter实现userId透传

你可能感兴趣的:(日志,java,MDC,分布式链路日志)