SkyWalking如何实现跨线程Trace传递

一、概述

SkyWalking 的中构建 Trace 信息时会借助 ThreadLocal来存储一些上下文信息,当遇到跨线程的时候,如果 Trace 的上下文信息没有传递到新线程的ThreadLocal 中,那么链路就断开了。那么SkyWalking是如何解决这个问题的呢?

二、实现原理

通过对 Callable、Runnable、Supplier 这3种接口的实现者进行增强拦截,将 Trace 的上下文信息传递到子线程中,实现了异步链路追踪。
在这里插入图片描述

三、内部原理

在这里插入图片描述
线程A

  • 调用ContextManager.capture()将 Trace 的上下文信息保存到一个ContextSnapshot的实例中。
  • ContextSnapshot则被附加到任务对象的SkyWalking-DynamicField属性中,那么当线程B接触到任务对象时,便能感知到ContextSnapshot。

线程B

  • 线程B中,在任务对象的任务方法被执行前,从任务对象的SkyWalking-DynamicField属性中获取ContextSnapshot对象,从中解析出 Trace 的信息后,存储到线程B的线程上下文中。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值