微服务分布式架构中,如何实现日志链路跟踪?

MDC(Mapped Diagnostic Context,映射调试上下文)是 log4j 和 logback 提供的一种方便在多线程条件下记录日志的功能MDC 可以看成是一个与当前线程绑定的Map,可以往其中添加键值对

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

#方案实现

由于MDC内部使用的是ThreadLocal所以只有本线程才有效,子线程和下游的服务MDC里的值会丢失;所以方案主要的难点是解决值的传递问题,主要包括以几下部分:

  • API网关中的MDC数据如何传递给下游服务

  • 服务如何接收数据,并且调用其他远程服务时如何继续传递

  • 异步的情况下(线程池)如何传给子线程

####修改日志模板

logback配置文件日志格式添加该标识

####网关添加过滤器

此过滤器就是来解决网关如何把MDC的数据传递给下游服务:

生成traceId并通过header传递给下游服务

你可能感兴趣的:(程序员,架构,微服务,分布式)