日志框架log4j打印异常堆栈信息携带traceId,方便接口异常排查
一、异常堆栈无traceId 排查定位问题异常痛苦
在日常项目开发中,我们会自定义一个traceId方便,链路追踪。在log4j2.xml 我们可能是这样去配置日志打印格式。
<Console name="CONSOLE" target="SYSTEM_OUT">
<PatternLayout
pattern="${APP_NAME} %-d{yyyy-MM-dd HH:mm:ss} [%-5p] [%X{TRACE_ID}] (%c{1}:%L) %m%n"/>
</Console>
这样配置后,日常堆栈打印效果是这样的,报错输出的堆栈,没有携带trace_id信息,这样在做日志筛查时候,非常不方便。不能快速定位异常代码位置。
二、如何修改log4j.xml,让堆栈末尾添加traceId信息
我们可以通过%xthrowable 配合{suffix(pattern)}使用,在每个堆栈帧的末尾添加trace_id输出。
${APP_NAME} %-d{yyyy-MM-dd HH:mm:ss} [%-5p] [%X{TRACE_ID}] %xThrowable{suffix(%X{TRACE_ID})} (%c{1}:%L) %m%n
添加后,验证效果,堆栈信息末尾都添加了traceId。