上下文传播

了解实现分布式追踪的概念。

The content of this page may be outdated and some links may be invalid. A newer version of this page exists in English.

More information ...

To see the changes to the English page since this page was last updated: visit GitHub compare 7bb7dbb6..9a1f7271 and search for content/en/docs/concepts/context-propagation.md.

通过上下文传播,无论信号在何处生成,信号彼此之间都可以相互关联。 尽管上下文传播的作用不仅限于链路追踪, 但上下文传播允许链路跨进程和网络边界任意分布的服务来构建相关系统的关联信息。

要理解上下文传播,你需要理解两个独立的概念:上下文和传播。

上下文

**上下文(Context)**这个对象包含了发送和接收服务或执行单元的信息, 用于将一个信号与另一个信号关联起来。

当 Service A 调用 Service B 时,会在上下文中包含一个链路 ID和一个 Span ID。 Service B 使用这些值创建属于同一个链路的新 Span,并将 Service A 的 Span 设置为其父。 这使得可以在跨服务边界的情况下追踪请求的完整流转过程。

传播

**传播(Propagation)**是上下文在服务和进程之间移动的机制。 它序列化或反序列化上下文对象并提供要从一个服务传播到另一个服务的相关信息。

传播通常由插桩库进行处理,对用户是透明的。如果你需要手动传播上下文,你可以使用 Propagators API

OpenTelemetry 维护着几个官方传播器。默认传播器使用 W3C 追踪上下文规范指定的标头。

规范

要了解有关上下文传播的更多信息,请参阅上下文规范