版权说明: 本文由博主keep丶原创,转载请保留此块内容在文首。
原文地址: https://blog.csdn.net/qq_38688267/article/details/144842327
文章目录
- 背景
- 设计日志格式
- 实现
- 配置动态取值
- logback-spring.xml
背景
多个单体服务间存在少量交互,需实现简易链路追踪功能如下图。设计链路标识traceId,实现Logback日志模板设置成动态参数输出到日志中。
设计日志格式
如下图,在日志输出中增加traceId列,且该列值如线程值一样动态改变。
实现
配置动态取值
- 配置动态参数获取类
import ch.qos.logback.core.PropertyDefinerBase;/*** Logback日志动态参数traceId的值获取类* <br/>* 在{@code logback-spring.xml}中使用* @author zeng.zf*/
public class TraceLogConversion extends PropertyDefinerBase {@Overridepublic String getPropertyValue() {return TraceLocalCache.get();}
}
- 配置映射
logback-spring.xml
日志格式化pattern值如下,pattern值中定义了
traceId
动态参数
%green(%d{${LOG_DATEFORMAT_PATTERN:-yyyy-MM-dd HH:mm:ss.SSS}})|%highlight(${LOG_LEVEL_PATTERN:-%5p})|%t|%magenta(%X{traceId})|%cyan(%logger{100}.%M\\(%L\\)):%m%n
至此,即可实现动态参数。