Data Model¶
Traces in OpenTracing are defined implicitly by their Spans.
In particular, a Trace can be thought of as a directed acyclic graph (DAG) of Spans,
where the edges between Spans are called References.
Trace¶
Trace表示一次完整的追踪链路,trace由一个或多个span组成。下图示例表示了一个由8个span组成的trace:
[Span A] ←←←(the root span)
|
+------+------+
| |
[Span B] [Span C] ←←←(Span C is a `ChildOf` Span A)
| |
[Span D] +---+-------+
| |
[Span E] [Span F] >>> [Span G] >>> [Span H]
↑
↑
↑
(Span G `FollowsFrom` Span F)
时间轴的展现方式会更容易理解:
––|–––––––|–––––––|–––––––|–––––––|–––––––|–––––––|–––––––|–> time
[Span A···················································]
[Span B··············································]
[Span D··········································]
[Span C········································]
[Span E·······] [Span F··] [Span G··] [Span H··]
Span¶
Span是一条追踪链路中的基本组成要素,一个span表示一个独立的工作单元,比如可以表示一次函数调用,一次http请求等等。span会记录如下基本要素:
1. 服务名称(operation name)
2. 服务的开始时间和结束时间
3. K/V形式的Tags
4. K/V形式的Logs
5. SpanContext
6. References:该span对一个或多个span的引用(通过引用SpanContext)
Each Span encapsulates the following state:
1. An operation **name**
2. A **start** timestamp
3. A **finish** timestamp
4. A set of zero or more key:value **Span Tags**.
The keys must be strings.
The values may be strings, bools, or numeric types.
5. A set of zero or more **Span Logs**,
each of which is itself a key:value map paired with a timestamp.
The keys must be strings, though the values may be of any type.
Not all OpenTracing implementations must support every value type.
6. A **SpanContext**
Any OpenTracing-implementation-dependent state (for example, trace and span ids)
needed to refer to a distinct Span across a process boundary
Baggage Items, which are just key:value pairs that cross process boundaries
7. **References** to zero or more causally-related Spans
(via the SpanContext of those related Spans)
Logs¶
Logs与tags类似,也是K/V键值对形式。与tags不同的是,logs还会记录写入logs的时间,因此logs主要用于记录某些事件发生的时间。logs的key值同样必须为字符串,但对value类型则没有限制。例如:
span.LogFields(
log.String("event", "soft error"),
log.String("type", "cache timeout"),
log.Int("waited.millis", 1500),
)
Opentracing列举了一些惯用的Tags和Logs: https://github.com/opentracing/specification/blob/master/semantic_conventions.md
SpanContext¶
SpanContext携带着一些用于跨服务通信的(跨进程)数据,主要包含:
足够在系统中标识该span的信息,比如:span_id,trace_id
Baggage Items,为整条追踪连保存跨服务(跨进程)的K/V格式的用户自定义数据
Baggage Items¶
Baggage Items与tags类似,也是K/V键值对。与tags不同的是:
其key跟value都只能是字符串格式
Baggage items不仅当前span可见,其会随着SpanContext传递给后续所有的子span
注意: 要小心谨慎的使用baggage items——因为在所有的span中传递这些K,V会带来不小的网络和CPU开销
References¶
Opentracing定义了两种引用关系:
ChildOf FollowFrom
ChildOf:
父span的执行依赖子span的执行结果时: 此时子span对父span的引用关系是ChildOf 比如对于一次RPC调用,服务端的span(子span)与客户端调用的span(父span)是ChildOf关系
FollowFrom:
父span的执行不依赖子span执行结果时: 此时子span对父span的引用关系是FollowFrom FollowFrom常用于异步调用的表示 例如消息队列中consumerspan与producerspan之间的关系