Java应用日志追踪:最佳实践
高效追踪Java应用中不同请求的日志,关键在于为每个请求生成唯一的标识符。本文推荐使用Spring拦截器、日志格式化和Log4j的MDC(Mapped Diagnostic Context)机制来实现这一目标。
实现步骤:
%x{requestId}。 示例配置(基于logback):%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %x{requestId} - %msg%n
HandlerInterceptor接口。在preHandle方法中,生成UUID作为请求ID,并使用MDC存储该ID。@Component
public class RequestIdInterceptor implements HandlerInterceptor {
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
String requestId = UUID.randomUUID().toString();
MDC.put("requestId", requestId);
return true;
}
@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object
handler, Exception ex) throws Exception {
MDC.remove("requestId");
}
}
@Configuration
public class WebConfig implements WebMvcConfigurer {
@Autowired
private RequestIdInterceptor requestIdInterceptor;
@Override
public void addInterceptors(InterceptorRegistry registry) {
registry.addInterceptor(requestIdInterceptor).addPathPatterns("/**").excludePathPatterns("/static/**");
}
}
requestId字段,实现对不同请求日志的追踪。通过以上步骤,每个HTTP请求都会拥有唯一的requestId,方便追踪和分析日志,提高问题排查效率。 请根据实际使用的日志框架(Log4j2, Logback等)调整相应的配置。