解决接入sleuth链路追踪后xxl-job定时任务的日志无日志问题

问题背景

随着业务规模的不断的增大, 系统的复杂度也越来越高, 公司软件架构也进入到了分布式微服务的阶段, 在这样的情况下每一次请求都有可能跨越多个项目, 传统的日志监控方式无法满足调用链路追踪, 这就导致问题定位/诊断服务变得复杂。所以我们引入了sleuth这一链路追踪框架为每一次请求的所有日志赋予一个traceId以方便日志的追溯。但是使用中发现xxl-job的日志是没有traceId的,只能根据线程id来筛选日志,且跨服务后的日志查不到了。为了解决这个问题,查阅了一些资料后找到了解决方案。

即通过使用Spring aop的方式在请求时向MDC注入traceId方法成功解决了这个问题。解决代码如下(@Before里的地址需要换成自己项目Job的类名):

java 复制代码
import lombok.extern.slf4j.Slf4j;
import org.apache.commons.codec.digest.DigestUtils;
import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.slf4j.MDC;
import org.springframework.stereotype.Component;
import java.util.UUID;

@Aspect
@Component
@Slf4j
public class JobTraceLogAspect {
 	private static final String TRACE_ID = "traceIdd";
    private static final String SPAN_ID = "spanId";
    
    @Before("execution(public * com.xxl.job..*.execute(String))")
    public void beforeMethod(JoinPoint joinPoint){
    	// 注入traceId
    	String val = UUID.randomUUID().toString().replace("-","");
        MDC.put(TRACE_ID, val);
        MDC.put(SPAN_ID, val);

		// 定时任务统一日志(如果不需要也可以去掉)
   		String className = joinPoint.getTarget().getClass().getSimpleName();
    	String methodName = joinPoint.getSignature().getName();
   		String args = JSON.toJSONString(joinPoint.getArgs(), SerializerFeature.IgnoreNonFieldGetter);
    	log.info("执行定时任务:{}.{},参数:{}", className, methodName, args);
    }
}

通过增加以上类,即可实现traceId注入,同时也增加了统一日志打印,不需要在每个定时任务入口都打印日志(如果不需要也可以去掉)。

相关推荐
LUCIAZZZ8 天前
简单介绍分布式定时任务XXL-JOB
java·spring boot·分布式·spring·操作系统·定时任务
LUCIAZZZ16 天前
分布式链路追踪理论
java·分布式·中间件·操作系统·链路追踪
Thanks_ks18 天前
Python 自动化办公:Excel 数据处理的“秘密武器”
pandas·定时任务·openpyxl·批量处理·销售数据分析·excel 数据处理·python 办公自动化
mask哥18 天前
详解最新链路追踪skywalking框架介绍、架构、环境本地部署&配置、整合微服务springcloudalibaba 、日志收集、自定义链路追踪、告警等
java·spring cloud·架构·gateway·springboot·skywalking·链路追踪
LUCIAZZZ1 个月前
说一下java的探针agent的应用场景
java·spring boot·spring·agent·链路追踪
遇码1 个月前
单机快速部署开源、免费的分布式任务调度系统——DolphinScheduler
大数据·运维·分布式·开源·定时任务·dolphin·scheduler
不会飞的小龙人2 个月前
Docker安装Jaeger链路追踪平台
docker·链路追踪·portainer·jaeger·日志埋点
灰色人生qwer3 个月前
SpringBoot项目注入 traceId 来追踪整个请求的日志链路
java·spring boot·后端·日志·slf4j·链路追踪
随风奔跑尿飞扬3 个月前
分享一下可观测体系的实现
云原生·链路追踪·可观测·opentelemetry
gqkmiss3 个月前
Electron 客户端心跳定时任务调度库调研文档 - Node.js 任务调度库技术调研文档
javascript·electron·node.js·定时任务·任务调度