Spring实现Logback日志模板设置动态参数功能
版权说明: 本文由博主keep丶原创,转载请保留此块内容在文首。
原文地址: https://blog.csdn.net/qq_38688267/article/details/144842327
背景
多个单体服务间存在少量交互,需实现简易链路追踪功能如下图。设计链路标识traceId,实现Logback日志模板设置成动态参数输出到日志中。

设计日志格式
如下图,在日志输出中增加traceId列,且该列值如线程值一样动态改变。

实现
配置动态取值
配置动态参数获取类
import ch.qos.logback.core.PropertyDefinerBase;
/**
* Logback日志动态参数traceId的值获取类
* <br/>
* 在{@code logback-spring.xml}中使用
* @author zeng.zf
*/
public class TraceLogConversion extends PropertyDefinerBase {
@Override
public 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至此,即可实现动态参数。
相关资料
到此这篇关于Spring实现Logback日志模板设置动态参数的文章就介绍到这了,更多相关Spring Logback动态参数内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
MybatisPlus使用Mybatis的XML的动态SQL的功能实现多表查询
本文主要介绍了MybatisPlus使用Mybatis的XML的动态SQL的功能实现多表查询,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2023-11-11
Eclipse中查看android工程代码出现"android.jar has no source attachment
这篇文章主要介绍了Eclipse中查看android工程代码出现"android.jar has no source attachment"的解决方案,需要的朋友可以参考下2016-05-05
浅谈java中Math.random()与java.util.random()的区别
下面小编就为大家带来一篇浅谈java中Math.random()与java.util.random()的区别。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧2016-09-09


最新评论