Documentation ¶
Overview ¶
Package trace contains types for representing trace information, and functions for global configuration of tracing.
The following assumes a basic familiarity with OpenCensus concepts. See http://opencensus.io.
Enabling Tracing for a Program ¶
To use OpenCensus tracing, register at least one Exporter. You can use one of the provided exporters or write your own.
trace.RegisterExporter(anExporter)
By default, traces will be sampled relatively rarely. To change the sampling frequency for your entire program, call SetDefaultSampler. Use a ProbabilitySampler to sample a subset of traces, or use AlwaysSample to collect a trace on every run:
trace.SetDefaultSampler(trace.AlwaysSample())
Adding Spans to a Trace ¶
A trace consists of a tree of spans. In Go, the current span is carried in a context.Context.
It is common to want to capture all the activity of a function call in a span. For this to work, the function must take a context.Context as a parameter. Add these two lines to the top of the function:
ctx = trace.StartSpan(ctx, "your choice of name") defer trace.EndSpan(ctx)
StartSpan will create a child span if one already exists, and will create a new top-level span otherwise.
As a suggestion, use the fully-qualified function name as the span name, e.g. "github.com/me/mypackage.Run".
Index ¶
- func AddLink(ctx context.Context, l Link)
- func AddMessageReceiveEvent(ctx context.Context, messageID, uncompressedByteSize, compressedByteSize int64)
- func AddMessageSendEvent(ctx context.Context, messageID, uncompressedByteSize, compressedByteSize int64)
- func ConfigureBucketSizes(bcs []BucketConfiguration)
- func EndSpan(ctx context.Context)
- func IsRecordingEvents(ctx context.Context) bool
- func IsSampled(ctx context.Context) bool
- func LazyPrint(ctx context.Context, str fmt.Stringer)
- func LazyPrintWithAttributes(ctx context.Context, attributes []Attribute, str fmt.Stringer)
- func LazyPrintf(ctx context.Context, format string, a ...interface{})
- func LazyPrintfWithAttributes(ctx context.Context, attributes []Attribute, format string, a ...interface{})
- func Print(ctx context.Context, str string)
- func PrintWithAttributes(ctx context.Context, attributes []Attribute, str string)
- func RegisterExporter(e Exporter)
- func SampledSpansSummary() map[string]PerMethodSummary
- func SetDefaultSampler(sampler Sampler)
- func SetSpanAttributes(ctx context.Context, attributes ...Attribute)
- func SetSpanStatus(ctx context.Context, status Status)
- func SetStackTrace(ctx context.Context)
- func StartSpan(ctx context.Context, name string) context.Context
- func StartSpanWithOptions(ctx context.Context, name string, o StartSpanOptions) context.Context
- func StartSpanWithRemoteParent(ctx context.Context, name string, parent SpanContext, o StartSpanOptions) context.Context
- func UnregisterExporter(e Exporter)
- func WithSpan(parent context.Context, s *Span) context.Context
- type Annotation
- type Attribute
- type BoolAttribute
- type BucketConfiguration
- type ErrorBucketSummary
- type Exporter
- type Int64Attribute
- type LatencyBucketSummary
- type Link
- type LinkType
- type MessageEvent
- type MessageEventType
- type PerMethodSummary
- type Sampler
- type SamplingDecision
- type SamplingParameters
- type Span
- func (s *Span) AddLink(l Link)
- func (s *Span) AddMessageReceiveEvent(messageID, uncompressedByteSize, compressedByteSize int64)
- func (s *Span) AddMessageSendEvent(messageID, uncompressedByteSize, compressedByteSize int64)
- func (s *Span) End()
- func (s *Span) IsRecordingEvents() bool
- func (s *Span) IsSampled() bool
- func (s *Span) LazyPrint(str fmt.Stringer)
- func (s *Span) LazyPrintWithAttributes(attributes []Attribute, str fmt.Stringer)
- func (s *Span) LazyPrintf(format string, a ...interface{})
- func (s *Span) LazyPrintfWithAttributes(attributes []Attribute, format string, a ...interface{})
- func (s *Span) Print(str string)
- func (s *Span) PrintWithAttributes(attributes []Attribute, str string)
- func (s *Span) SetAttributes(attributes ...Attribute)
- func (s *Span) SetStackTrace()
- func (s *Span) SetStatus(status Status)
- func (s *Span) SpanContext() SpanContext
- func (s *Span) StartSpan(name string) *Span
- func (s *Span) StartSpanWithOptions(name string, o StartSpanOptions) *Span
- func (s *Span) String() string
- type SpanContext
- type SpanData
- type SpanID
- type StartSpanOptions
- type Status
- type StringAttribute
- type TraceID
- type TraceOptions
Examples ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func AddMessageReceiveEvent ¶
func AddMessageReceiveEvent(ctx context.Context, messageID, uncompressedByteSize, compressedByteSize int64)
AddMessageReceiveEvent adds a message receive event to the current span.
messageID is an identifier for the message, which is recommended to be unique in this span and the same between the send event and the receive event (this allows to identify a message between the sender and receiver). For example, this could be a sequence id.
func AddMessageSendEvent ¶
func AddMessageSendEvent(ctx context.Context, messageID, uncompressedByteSize, compressedByteSize int64)
AddMessageSendEvent adds a message send event to the current span.
messageID is an identifier for the message, which is recommended to be unique in this span and the same between the send event and the receive event (this allows to identify a message between the sender and receiver). For example, this could be a sequence id.
func ConfigureBucketSizes ¶
func ConfigureBucketSizes(bcs []BucketConfiguration)
ConfigureBucketSizes sets the number of spans to keep per latency and error bucket for different span names.
func EndSpan ¶
EndSpan ends the current span.
The context passed to EndSpan will still refer to the now-ended span, so any code that adds more information to it, like SetSpanStatus, should be called before EndSpan.
func IsRecordingEvents ¶
IsRecordingEvents returns true if events are being recorded for the current span.
func LazyPrint ¶
LazyPrint adds an annotation to the current span using a fmt.Stringer.
str.String is called only when the annotation text is needed.
func LazyPrintWithAttributes ¶
LazyPrintWithAttributes adds an annotation with attributes to the current span using a fmt.Stringer.
str.String is called only when the annotation text is needed.
func LazyPrintf ¶
LazyPrintf adds an annotation to the current span.
The format string is evaluated with its arguments only when the annotation text is needed.
func LazyPrintfWithAttributes ¶
func LazyPrintfWithAttributes(ctx context.Context, attributes []Attribute, format string, a ...interface{})
LazyPrintfWithAttributes adds an annotation with attributes to the current span.
The format string is evaluated with its arguments only when the annotation text is needed.
func PrintWithAttributes ¶
PrintWithAttributes adds an annotation with attributes to the current span.
func RegisterExporter ¶
func RegisterExporter(e Exporter)
RegisterExporter adds to the list of Exporters that will receive sampled trace spans.
func SampledSpansSummary ¶
func SampledSpansSummary() map[string]PerMethodSummary
SampledSpansSummary returns a summary of what spans are being stored for each span name.
func SetDefaultSampler ¶
func SetDefaultSampler(sampler Sampler)
SetDefaultSampler sets the default sampler used when creating new spans.
func SetSpanAttributes ¶
SetSpanAttributes sets attributes in the current span.
Existing attributes whose keys appear in the attributes parameter are overwritten.
func SetSpanStatus ¶
SetSpanStatus sets the status of the current span, if it is recording events.
func SetStackTrace ¶
SetStackTrace adds a stack trace to the current span.
func StartSpan ¶
StartSpan starts a new child span of the current span in the context.
If there is no span in the context, creates a new trace and span.
Example ¶
This example shows how to use StartSpan and EndSpan to capture a function execution in a Span. It assumes that the function has a context.Context argument.
package main import ( "fmt" "go.opencensus.io/trace" "golang.org/x/net/context" ) func main() { printEvens := func(ctx context.Context) { ctx = trace.StartSpan(ctx, "my/package.Function") defer trace.EndSpan(ctx) for i := 0; i < 10; i++ { if i%2 == 0 { fmt.Printf("Even!\n") } } } ctx := context.Background() printEvens(ctx) }
Output:
func StartSpanWithOptions ¶
StartSpanWithOptions starts a new child span of the current span in the context.
If there is no span in the context, creates a new trace and span.
func StartSpanWithRemoteParent ¶
func StartSpanWithRemoteParent(ctx context.Context, name string, parent SpanContext, o StartSpanOptions) context.Context
StartSpanWithRemoteParent starts a new child span with the given parent SpanContext.
If there is an existing span in ctx, it is ignored -- the returned Span is a child of the span specified by parent.
func UnregisterExporter ¶
func UnregisterExporter(e Exporter)
UnregisterExporter removes from the list of Exporters the Exporter that was registered with the given name.
Types ¶
type Annotation ¶
Annotation represents a text annotation with a set of attributes and a timestamp.
type Attribute ¶
type Attribute interface {
// contains filtered or unexported methods
}
Attribute is an interface for attributes; it is implemented by BoolAttribute, IntAttribute, and StringAttribute.
type BoolAttribute ¶
BoolAttribute represents a bool-valued attribute.
type BucketConfiguration ¶
BucketConfiguration stores the number of samples to store for span buckets for successful and failed spans for a particular span name.
type ErrorBucketSummary ¶
ErrorBucketSummary is a summary of an error bucket.
type Exporter ¶
type Exporter interface {
Export(s *SpanData)
}
Exporter is a type for functions that receive sampled trace spans.
The Export method should return quickly; if an Exporter takes a significant amount of time to process a SpanData, that work should be done on another goroutine.
The SpanData should not be modified, but a pointer to it can be kept.
type Int64Attribute ¶
Int64Attribute represents an int64-valued attribute.
type LatencyBucketSummary ¶
LatencyBucketSummary is a summary of a latency bucket.
type Link ¶
type Link struct { TraceID SpanID Type LinkType // Attributes is a set of attributes on the link. Attributes map[string]interface{} }
Link represents a reference from one span to another span.
type LinkType ¶
type LinkType int32
LinkType specifies the relationship between the span that had the link added, and the linked span.
type MessageEvent ¶
type MessageEvent struct { time.Time EventType MessageEventType MessageID int64 UncompressedByteSize int64 CompressedByteSize int64 }
MessageEvent represents an event describing a message sent or received on the network.
type MessageEventType ¶
type MessageEventType int32
MessageEventType specifies the type of message event.
const ( MessageEventTypeUnspecified MessageEventType = iota // Unknown event type. MessageEventTypeSent // Indicates a sent RPC message. MessageEventTypeRecv // Indicates a received RPC message. )
MessageEventType values.
type PerMethodSummary ¶
type PerMethodSummary struct { Active int LatencyBuckets []LatencyBucketSummary ErrorBuckets []ErrorBucketSummary }
PerMethodSummary is a summary of the spans stored for a single span name.
type Sampler ¶
type Sampler interface {
Sample(p SamplingParameters) SamplingDecision
}
Sampler is an interface for values that have a method that the trace library can call to determine whether to export a trace's spans.
func AlwaysSample ¶
func AlwaysSample() Sampler
AlwaysSample returns a Sampler that samples every trace.
func ProbabilitySampler ¶
ProbabilitySampler returns a Sampler that samples a given fraction of traces.
It also samples spans whose parents are sampled.
type SamplingDecision ¶
type SamplingDecision struct {
Sample bool
}
SamplingDecision is the value returned by a Sampler.
type SamplingParameters ¶
type SamplingParameters struct { ParentContext SpanContext TraceID SpanID Name string HasRemoteParent bool }
SamplingParameters contains the values passed to a Sampler.
type Span ¶
type Span struct {
// contains filtered or unexported fields
}
Span represents a span of a trace. It has an associated SpanContext, and stores data accumulated while the span is active.
Ideally users should interact with Spans by calling the functions in this package that take a Context parameter.
func FromContext ¶
FromContext returns the Span stored in a context, or nil if there isn't one.
func NewSpan ¶
func NewSpan(name string, o StartSpanOptions) *Span
NewSpan returns a new span.
The returned span has no parent span; a new trace ID will be created for it.
func NewSpanWithRemoteParent ¶
func NewSpanWithRemoteParent(name string, parent SpanContext, o StartSpanOptions) *Span
NewSpanWithRemoteParent returns a new span with the given parent SpanContext.
func (*Span) AddMessageReceiveEvent ¶
AddMessageReceiveEvent adds a message receive event to the span.
messageID is an identifier for the message, which is recommended to be unique in this span and the same between the send event and the receive event (this allows to identify a message between the sender and receiver). For example, this could be a sequence id.
func (*Span) AddMessageSendEvent ¶
AddMessageSendEvent adds a message send event to the span.
messageID is an identifier for the message, which is recommended to be unique in this span and the same between the send event and the receive event (this allows to identify a message between the sender and receiver). For example, this could be a sequence id.
func (*Span) IsRecordingEvents ¶
IsRecordingEvents returns true if events are being recorded for this span.
func (*Span) LazyPrint ¶
LazyPrint adds an annotation using a fmt.Stringer.
str.String is called only when the annotation text is needed.
func (*Span) LazyPrintWithAttributes ¶
LazyPrintWithAttributes adds an annotation with attributes using a fmt.Stringer.
str.String is called only when the annotation text is needed.
func (*Span) LazyPrintf ¶
LazyPrintf adds an annotation.
The format string is evaluated with its arguments only when the annotation text is needed.
func (*Span) LazyPrintfWithAttributes ¶
LazyPrintfWithAttributes adds an annotation with attributes.
The format string is evaluated with its arguments only when the annotation text is needed.
func (*Span) PrintWithAttributes ¶
PrintWithAttributes adds an annotation with attributes.
func (*Span) SetAttributes ¶
SetAttributes sets attributes in the span.
Existing attributes whose keys appear in the attributes parameter are overwritten.
func (*Span) SetStackTrace ¶
func (s *Span) SetStackTrace()
SetStackTrace adds a stack trace to the span.
func (*Span) SpanContext ¶
func (s *Span) SpanContext() SpanContext
SpanContext returns the SpanContext of the span.
func (*Span) StartSpan ¶
StartSpan starts a new child span.
If s is nil, creates a new trace and span, like the function NewSpan.
func (*Span) StartSpanWithOptions ¶
func (s *Span) StartSpanWithOptions(name string, o StartSpanOptions) *Span
StartSpanWithOptions starts a new child span using the given options.
If s is nil, creates a new trace and span, like the function NewSpan.
type SpanContext ¶
type SpanContext struct { TraceID SpanID TraceOptions }
SpanContext contains the state that must propagate across process boundaries.
SpanContext is not an implementation of context.Context. TODO: add reference to external Census docs for SpanContext.
func SpanContextFromContext ¶
func SpanContextFromContext(ctx context.Context) (SpanContext, bool)
SpanContextFromContext returns the SpanContext of the current span, if there is one.
func (SpanContext) IsSampled ¶
func (sc SpanContext) IsSampled() bool
IsSampled returns true if the span will be exported.
type SpanData ¶
type SpanData struct { SpanContext ParentSpanID SpanID Name string StartTime time.Time EndTime time.Time // The values of Attributes each have type string, bool, or int64. Attributes map[string]interface{} Annotations []Annotation MessageEvents []MessageEvent Status StackTrace []uintptr Links []Link HasRemoteParent bool }
SpanData contains all the information collected by a Span.
func ActiveSpans ¶
ActiveSpans returns the active spans for the given name.
func ErrorSampledSpans ¶
ErrorSampledSpans returns a sample of error spans.
If code is nonzero, only spans with that status code are returned.
func LatencySampledSpans ¶
LatencySampledSpans returns a sample of successful spans.
minLatency is the minimum latency of spans to be returned. maxLatency, if nonzero, is the maximum latency of spans to be returned.
type StartSpanOptions ¶
type StartSpanOptions struct { // RecordEvents indicates whether to record data for this span, and include // the span in a local span store. // Events will also be recorded if the span will be exported. RecordEvents bool Sampler // if non-nil, the Sampler to consult for this span. // RegisterNameForLocalSpanStore indicates that a local span store for spans // of this name should be created, if one does not exist. // If RecordEvents is false, this option has no effect. RegisterNameForLocalSpanStore bool }
StartSpanOptions contains options concerning how a span is started.
type Status ¶
type Status struct { // Code is a status code. Zero indicates success. // // If Code will be propagated to Google APIs, it ideally should be a value from // https://github.com/googleapis/googleapis/blob/master/google/rpc/code.proto . Code int32 Message string }
Status is the status of a Span.
type StringAttribute ¶
StringAttribute represents a string-valued attribute.
type TraceOptions ¶
type TraceOptions uint32
TraceOptions contains options associated with a trace span.
func (TraceOptions) IsSampled ¶
func (t TraceOptions) IsSampled() bool
IsSampled returns true if the span will be exported.
Source Files ¶
Directories ¶
Path | Synopsis |
---|---|
Package propagation implements the binary trace context format.
|
Package propagation implements the binary trace context format. |