Tracing APIs

Add trace Toolkit

toolkit/trace provides the APIs to enhance the trace context, such as createLocalSpan, createExitSpan, createEntrySpan, log, tag, prepareForAsync and asyncFinish. Add the toolkit/trace dependency to your project.

import "github.com/apache/skywalking-go/toolkit/trace"

Use Native Tracing

Context Carrier

The context carrier is used to pass the context between the difference application.

When creating an Entry Span, you need to obtain the context carrier from the request. When creating an Exit Span, you need to write the context carrier into the target RPC request.

type ExtractorRef func(headerKey string) (string, error)

type InjectorRef func(headerKey, headerValue string) error

The following demo demonstrates how to pass the Context Carrier in the Tracing API:

// create a new entry span and extract the context carrier from the request
trace.CreateEntrySpan("EntrySpan", func(headerKey string) (string, error) {
    return request.Header.Get(headerKey), nil
})

// create a new exit span and inject the context carrier into the request
trace.CreateExitSpan("ExitSpan", request.Host, func(headerKey, headerValue string) error {
	request.Header.Add(headerKey, headerValue)
	return nil
})

Create Span

Use trace.CreateEntrySpan() API to create entry span, and then use SpanRef to contain the reference of created span in agent kernel.

  • The first parameter is operation name of span
  • the second parameter is InjectorRef.
spanRef, err := trace.CreateEntrySpan("operationName", InjectorRef)

Use trace.CreateLocalSpan() API to create local span

  • the only parameter is the operation name of span.
spanRef, err := trace.CreateLocalSpan("operationName")

Use trace.CreateExitSpan() API to create exit span.

  • the first parameter is the operation name of span
  • the second parameter is the remote peer which means the peer address of exit operation.
  • the third parameter is the ExtractorRef
spanRef, err := trace.CreateExitSpan("operationName", "peer", ExtractorRef)

Use trace.StopSpan() API to stop current span

trace.StopSpan()

Add Span’s Tag and Log

Use trace.AddLog() to record log in span.

Use trace.SetTag() to add tag to span, the parameters of tag are two String which are key and value respectively.

trace.AddLog(...string)

trace.SetTag("key","value")

Set ComponentID

Use trace.SetComponent() to set the component id of the Span

  • the type of parameter is int32.
trace.SetComponent(ComponentID)

The Component ID in Span is used to identify the current component, which is declared in the component libraries YAML from the OAP server side.

Attach an event to a span

Use the trace.AddEvent(et EventType, event string) API to attach an event to the Span

Currently, we support the following four types of events:

// DebugEventType Indicates the event type is "debug"
DebugEventType EventType = "debug"

// InfoEventType Indicates the event type is "info"
InfoEventType EventType = "info"

// WarnEventType Indicates the event type is "warn"
WarnEventType EventType = "warn"

// ErrorEventType Indicates the event type is "error"
ErrorEventType EventType = "error"

For example, we can add a “request timeout” event:

trace.AddEvent(WarnEventType, "current request has timed out!")

Async Prepare/Finish

SpanRef is the return value of CreateSpan.Use SpanRef.PrepareAsync() to make current span still alive until SpanRef.AsyncFinish() called.

  • Call PrepareAsync().
  • Use trace.StopSpan() to stop span in the original goroutine.
  • Propagate the SpanRef to any other goroutine.
  • Call SpanRef.AsyncFinish() in any goroutine.

Capture/Continue Context Snapshot

  1. Use trace.CaptureContext() to get the segment info and store it in ContextSnapshotRef.
  2. Propagate the snapshot context to any other goroutine.
  3. Use trace.ContinueContext(snapshotRef) to load the snapshotRef in the target goroutine.

Reading Context

All following APIs provide readonly features for the tracing context from tracing system. The values are only available when the current thread is traced.

  • Use trace.GetTraceID() API to get traceID.

    traceID := trace.GetTraceID()
    
  • Use trace.GetSegmentID() API to get segmentID.

    segmentID := trace.GetSegmentID()
    
  • Use trace.GetSpanID() API to get spanID.

    spanID := trace.GetSpanID()
    

Trace Correlation Context

Trace correlation context APIs provide a way to put custom data in tracing context. All the data in the context will be propagated with the in-wire process automatically.

Use trace.SetCorrelation() API to set custom data in tracing context.

trace.SetCorrelation("key","value")
  • Max element count in the correlation context is 3
  • Max value length of each element is 128

CorrelationContext will remove the key when the value is empty.

Use trace.GetCorrelation() API to get custom data.

value := trace.GetCorrelation("key")