本项目源码已在多个项目中实践
接着,项目中使用了线程池,那么子线程中日志就会丢失traceId,下面讲解如何实现子线程中的traceId日志跟踪。
子线程在打印日志的过程中traceId将丢失,解决方式为重写线程池,将主线程的traceId继续传递到子线程中。当然,对于直接new创建线程的情况不考略【实际应用中应该避免这种用法】。
继承ThreadPoolExecutor,重写执行任务的方法
public final class OverrideThreadPoolExecutor extends ThreadPoolExecutor { @Override public void execute(Runnable task) { super.execute(ThreadMdcUtil.wrap(task, MDC.getCopyOfContextMap())); } @Override public <T> Future<T> submit(Runnable task, T result) { return super.submit(ThreadMdcUtil.wrap(task, MDC.getCopyOfContextMap()), result); } @Override public <T> Future<T> submit(Callable<T> task) { return super.submit(ThreadMdcUtil.wrap(task, MDC.getCopyOfContextMap())); } @Override public Future<?> submit(Runnable task) { return super.submit(ThreadMdcUtil.wrap(task, MDC.getCopyOfContextMap())); } }
封装ThreadMdcUtil工具类
以封装Callable为例:
public final class ThreadMdcUtil { public static void setTraceIdIfAbsent() { if (MDC.get(TraceConstant.MDC_TRACE) == null || MDC.get(TraceConstant.MDC_TRACE).length() == 0) { String tid = UUID.randomUUID().toString().replace("-", ""); MDC.put(TraceConstant.MDC_TRACE, tid); } } public static <T> Callable<T> wrap(final Callable<T> callable, final Map<String, String> context) { return () -> { if (context == null) { MDC.clear(); } else { MDC.setContextMap(context); } setTraceIdIfAbsent(); try { return callable.call(); } finally { MDC.clear(); } }; } }
@RestController @RequestMapping("trace") @Slf4j @AllArgsConstructor public class TestTraceController { private final ExecutorService executorService; @GetMapping("traceLog") public String traceLog() { log.info("---接口调用了---"); traceService(); asyncTrace(); return "success"; } private void traceService(){ log.error("## 执行traceService方法"); } private void asyncTrace(){ CompletableFuture.runAsync(()->{ log.info("执行线程池中的方法asyncTrace,未重写了线程池"); }, executorService); } }
未重写ThreadPoolExecutor效果如下:
重写ThreadPoolExecutor效果如下:
到此这篇关于SpringBoot+slf4j线程池全链路调用日志跟踪的文章就介绍到这了,更多相关SpringBoot全链路调用日志跟踪内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
免责声明:本站发布的内容(图片、视频和文字)以原创、来自本网站内容采集于网络互联网转载等其它媒体和分享为主,内容观点不代表本网站立场,如侵犯了原作者的版权,请告知一经查实,将立刻删除涉嫌侵权内容,联系我们QQ:712375056,同时欢迎投稿传递力量。
Copyright © 2009-2022 56dr.com. All Rights Reserved. 特网科技 特网云 版权所有 特网科技 粤ICP备16109289号
域名注册服务机构:阿里云计算有限公司(万网) 域名服务机构:烟台帝思普网络科技有限公司(DNSPod) CDN服务:阿里云计算有限公司 百度云 中国互联网举报中心 增值电信业务经营许可证B2
建议您使用Chrome、Firefox、Edge、IE10及以上版本和360等主流浏览器浏览本网站