logback中使用MDC自定义日志输出格式
logback-MDC
相当于自定义日志格式输出
写在过滤器中
示例:
try {
Context context = createContext(request, response);
processSysNo(request, response, context);
processSeqNo(request, response, context);
processTraceId(request, response, context);
MDC.put("systemName",context.getSysNo());
if (!StringUtils.isEmpty(context.getReqSeqNo())){
MDC.put("serialNum",context.getReqSeqNo());
}else {
MDC.put("serialNum",context.getSeqNo());
}
RuntimeMXBean runtimeMXBean = ManagementFactory.getRuntimeMXBean();
// 进程
MDC.put("process",runtimeMXBean.getName());
log.debug(context.toString());
chain.doFilter(request, response);
} finally {
removeContext(request, response);
// 避免线程泄漏
MDC.clear();
}
在logback.xml中配置引入
%X{process}
%X{systemName}
[时间戳] | 日志级别 | 所属系统或子系统 | traceId | spanId | 全局流水号 | 进程号 | 线程号 | 源码文件名:行号 | 日志内容
<pattern>[%d{yyyy-MM-dd HH:mm:ss}] | %-5level | %X{systemName} | %X{X-B3-TraceId:-} | %X{X-B3-SpanId:-} | %X{serialNum} | %X{process} | %thread | %class:%line | %msg%n</pattern>
定位问题原因*
根据原因思考问题解决方案*
实践验证方案有效性*
提交验证结果
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构