跳槽后,接到的第一个需求是在项目里给每个请求加一个唯一字符串,能够通过日志追踪到请求的整个流程。一个很简单的需求,上网查找资料考虑半天后,决定用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.nextLong()));
}
/- @description 删除本次请求的日志序列号
- @author jerry
- @date 2018-08
*/
pub