log4j的MDC配合Spring-mvc进行日志追踪

这篇博客介绍了如何利用log4j的MDC(Mapped Diagnostic Context)配合Spring-mvc实现请求日志追踪。首先创建一个日志工具类设置和移除MDC的序列值,然后定义一个拦截器在请求开始时插入序列值,并在结束时移除。在spring-mvc.xml中配置拦截器,并在log4j配置文件中定制日志输出格式以显示序列值。
摘要由CSDN通过智能技术生成

跳槽后,接到的第一个需求是在项目里给每个请求加一个唯一字符串,能够通过日志追踪到请求的整个流程。一个很简单的需求,上网查找资料考虑半天后,决定用log4j的MDC进行请求追踪。(logback和slf4j也是支持MDC)
因为我们项目是Spring-mvc和mybatis搭建的,页面请求都是直接转发到我们的controller层,所以考虑使用Spring的拦截器(interceptor)。inteceptor拦截所有请求,在preHandle中给请求赋唯一序列值,在afterCompletion中remove MDC的序列值。然后再log4j的配置文件中使用%X{logkey}输出请求的序列值。
另外唯一序列值我们采用的是随机数Math.abs(random.nextLong()),当然也可以采用UUID或者其他的都是OK的。
说了这么多,接下来就直接上代码吧。

第一步:新建一个日志工具类

import org.apache.log4j.MDC;
import java.util.Random;

/**

  • @description 日志工具类
    *@author jerry
    @date 2018-08
    /
    public class LoggerTools {
    /

    *@description 日志序列号
    *@author jerry
    @date 2018-08-03
    /
    public static void logger(){
    Random random=new Random();
    MDC.put(“logkey”,Math.abs(random.next
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值