tracing

package
v3.61.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Dec 28, 2021 License: MIT Imports: 3 Imported by: 0

Documentation

Overview

Package tracing implements utility functions for interacting with a global tracing system. Currently this system uses the opentracing APIs. However, eventually we will need to migrate to the new opentelemetry APIs, and therefore in order to reduce disruption this package abstracts interaction with these packages.

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func FinishSpans

func FinishSpans(msg types.Message)

FinishSpans calls Finish on all message parts containing a span.

func InitSpan

func InitSpan(operationName string, part types.Part) types.Part

InitSpan sets up an OpenTracing span on a message part if one does not already exist.

func InitSpanFromParent

func InitSpanFromParent(operationName string, parent *Span, part types.Part) types.Part

InitSpanFromParent sets up an OpenTracing span as children of a parent span on a message part if one does not already exist.

func InitSpans

func InitSpans(operationName string, msg types.Message)

InitSpans sets up OpenTracing spans on each message part if one does not already exist.

func InitSpansFromParent

func InitSpansFromParent(operationName string, parent *Span, msg types.Message)

InitSpansFromParent sets up OpenTracing spans as children of a parent span on each message part if one does not already exist.

func InitSpansFromParentTextMap

func InitSpansFromParentTextMap(operationName string, textMapGeneric map[string]interface{}, msg types.Message) error

InitSpansFromParentTextMap obtains a span parent reference from a text map and creates child spans for each message.

func IterateWithChildSpans

func IterateWithChildSpans(operationName string, msg types.Message, iter func(int, *Span, types.Part) error) error

IterateWithChildSpans iterates all the parts of a message and, for each part, creates a new span from an existing span attached to the part and calls a func with that span before finishing the child span.

func WithSiblingSpans

func WithSiblingSpans(operationName string, msg types.Message) types.Message

WithSiblingSpans takes a message, extracts spans per message part, creates new sibling spans, and returns a new message with those spans embedded. The original message is unchanged.

Types

type Span

type Span struct {
	// contains filtered or unexported fields
}

Span abstracts the span type of our global tracing system in order to allow it to be replaced in future.

func CreateChildSpan

func CreateChildSpan(operationName string, part types.Part) *Span

CreateChildSpan takes a message part, extracts an existing span if there is one and returns child span.

func CreateChildSpans

func CreateChildSpans(operationName string, msg types.Message) []*Span

CreateChildSpans takes a message, extracts spans per message part and returns a slice of child spans. The length of the returned slice is guaranteed to match the message size.

func GetSpan

func GetSpan(p types.Part) *Span

GetSpan returns a span attached to a message part. Returns nil if the part doesn't have a span attached.

func PartsWithChildSpans

func PartsWithChildSpans(operationName string, parts []types.Part) ([]types.Part, []*Span)

PartsWithChildSpans takes a slice of message parts, extracts spans per part, creates new child spans, and returns a new slice of parts with those spans embedded. The original parts are unchanged.

func WithChildSpans

func WithChildSpans(operationName string, msg types.Message) (types.Message, []*Span)

WithChildSpans takes a message, extracts spans per message part, creates new child spans, and returns a new message with those spans embedded. The original message is unchanged.

func (*Span) Finish

func (s *Span) Finish()

Finish the span.

func (*Span) LogKV

func (s *Span) LogKV(kv ...string)

LogKV adds log key/value pairs to the span.

func (*Span) SetTag

func (s *Span) SetTag(key string, value interface{})

SetTag sets a given tag to a value.

func (*Span) TextMap

func (s *Span) TextMap() (map[string]interface{}, error)

TextMap attempts to inject a span into a map object in text map format.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL