解决接入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注入,同时也增加了统一日志打印,不需要在每个定时任务入口都打印日志(如果不需要也可以去掉)。

相关推荐
__土块__2 小时前
AI 后台任务调度成功但未执行:从链路追踪到巡检策略的稳定性治理实践
可观测性·链路追踪·任务调度·系统稳定性·故障排查·管理后台·ai工程
twc8293 天前
【无标题】
软件测试·微服务·链路追踪
偶尔上线经常挺尸12 天前
《每日一命令09:crontab——让脚本自动运行》
备份·自动化运维·定时任务·crontab
zhoupenghui16815 天前
搭建VictoriaLogs集中式日志管理系统来解决 微服务 “请求跨越多个服务”时报错的全链路追踪与快速排查 问题
微服务·云原生·架构·链路追踪·victorialogs·logs explorer
Rubin智造社17 天前
OpenClaw实操指南21|HEARTBEAT心跳实战:让AI在你不说话时,自己主动干活
定时任务·heartbeat·自动化工作流·openclaw实操·workspace配置·心跳任务·每日简报
带娃的IT创业者1 个月前
WeClaw_40_系统监控与日志体系:多层次日志架构与Trace追踪
java·开发语言·python·架构·系统监控·日志系统·链路追踪
没有bug.的程序员1 个月前
100%采样率引发的全线熔断:Spring Boot 链路追踪的性能绞杀与物理级调优
java·spring boot·后端·生产·熔断·调优·链路追踪
boomworks2 个月前
定时执行专家V8.0 - 安装使用说明
定时任务·定时执行专家·定时任务管理软件·定时登录·日常办公
问道飞鱼2 个月前
【微服务相关】分布式定时任务 Quartz 全解析:从底层原理到 Spring Boot 实战
spring boot·分布式·微服务·quartz·定时任务