skywalking中TID

1.首先,需要明确TID的作用:

1.1分布式事务链路追踪

TID 作为全局唯一标识符,在分布式系统架构中实现端到端的请求追踪。当业务请求在微服务间流转时,TID 保持恒定不变,确保整个调用链路的完整性与可追溯性。

1.2 问题诊断与根因分析

在复杂分布式环境中,TID 为故障排查提供关键上下文信息。通过 TID 可快速关联跨服务的日志、指标和异常信息,精准定位性能瓶颈或故障点,显著提升系统可观测性。

2.TID是怎么获取到的呢?

TID是通过skywalking的agent探针生成的。
skywalking的架构图如下:

  • 上部分 Agent :负责从应用中,收集链路信息,发送给 SkyWalking OAP 服务器。目前支持 SkyWalking、Zikpin、Jaeger 等提供的 Tracing 数据信息。而我们目前采用的是,SkyWalking Agent 收集 SkyWalking Tracing 数据,传递给服务器。
  • 下部分 SkyWalking OAP :负责接收 Agent 发送的 Tracing 数据信息,然后进行分析(Analysis Core) ,存储到外部存储器( Storage ),最终提供查询( Query )功能。
  • 右部分 Storage :Tracing 数据存储。目前支持 ES、MySQL、Sharding Sphere、TiDB、H2 多种存储器。而我们目前采用的是 ES ,主要考虑是 SkyWalking 开发团队自己的生产环境采用 ES 为主。
  • 左部分 SkyWalking UI :负责提供控台,查看链路等等。
    关于TID我们只需要着重关注Agent和SkyWalking OAP部分即可。

2.1 Trace ID 来源

  • 生成源头:Trace ID 由 SkyWalking Agent 自动生成
  • 传播机制:通过 HTTP 头部 tid 在服务间传递
  • 链路追踪:同一个请求在所有微服务中使用相同的 Trace ID
    客户端请求链路的流程图如下:

客户端 SkyWalking Agent TraceIdFilter 业务处理 日志记录 下游服务 发送请求 检测请求头 是否存在 Trace ID 提取现有 Trace ID 生成新 Trace ID alt [存在 Trace ID] [不存在 Trace ID] 传递请求上下文 设置响应头 tid=${traceId} 继续过滤器链 处理业务逻辑 记录日志 携带 Trace ID 调用下游服务 通过 HTTP Header/RPC Context 传播 Trace ID 接收并处理请求 继续传播 Trace ID 客户端 SkyWalking Agent TraceIdFilter 业务处理 日志记录 下游服务

2.2SkyWalking 生效机制

2.2.1 自动注入

  • Java Agent:通过 JVM 参数加载 SkyWalking Agent
  • 字节码增强:在运行时修改类字节码,注入追踪逻辑
  • 上下文传播:自动管理 Trace Context 的创建和传递

2.2.2 链路追踪流程

  1. 请求入口:Agent 检测到 HTTP 请求,创建或提取 Trace Context
  2. ID 生成:生成全局唯一的 Trace ID 和本地的 Span ID
  3. 上下文传递:通过 ThreadLocal 和 HTTP 头部传递上下文
  4. 日志集成:MDC(Mapped Diagnostic Context) 自动注入 Trace ID
  5. 数据上报:追踪数据异步上报到 SkyWalking OAP Server
相关推荐
heimeiyingwang5 天前
【架构实战】链路追踪SkyWalking:让请求无所遁形
架构·skywalking
不懂的浪漫6 天前
OpenTelemetry 和 SkyWalking Agent 怎么选?一次讲清 OTel、SkyWalking Agent 的相同点与区别
wpf·skywalking·链路追踪·opentelemetry·otel
简简单单就是我_hehe9 天前
Webfunny Apm + SkyWalking Agent 全链路监控实战:从集成到问题排查
skywalking
phltxy11 天前
分布式链路追踪实战:Apache SkyWalking 从入门到精通
分布式·apache·skywalking
苍煜14 天前
SkyWalking最新实操入门博客:微服务可观测性搭建+原理详解+从零部署+UI使用教程
ui·微服务·skywalking
KK溜了溜了16 天前
Skywalking
skywalking
雨辰AI16 天前
SpringBoot3 + 人大金仓 V9 微服务监控实战|Prometheus+Grafana+SkyWalking 全链路监控
数据库·后端·微服务·grafana·prometheus·skywalking
随风,奔跑20 天前
Spring Cloud Alibaba(六)-链路追踪SkyWalking
java·后端·spring·skywalking
tsyjjOvO21 天前
分布式事务 Seata 与链路追踪 SkyWalking 全解析
分布式·skywalking
小旭952721 天前
分布式事务 Seata 详解 + 链路追踪 SkyWalking 实战
java·分布式·后端·信息可视化·skywalking