Source File
span_processor.go
Belonging Package
go.opentelemetry.io/otel/sdk/trace
// Copyright The OpenTelemetry Authors// SPDX-License-Identifier: Apache-2.0package trace // import "go.opentelemetry.io/otel/sdk/trace"import ()// SpanProcessor is a processing pipeline for spans in the trace signal.// SpanProcessors registered with a TracerProvider and are called at the start// and end of a Span's lifecycle, and are called in the order they are// registered.type SpanProcessor interface {// DO NOT CHANGE: any modification will not be backwards compatible and// must never be done outside of a new major release.// OnStart is called when a span is started. It is called synchronously// and should not block.OnStart(parent context.Context, s ReadWriteSpan)// DO NOT CHANGE: any modification will not be backwards compatible and// must never be done outside of a new major release.// OnEnd is called when span is finished. It is called synchronously and// hence not block.OnEnd(s ReadOnlySpan)// DO NOT CHANGE: any modification will not be backwards compatible and// must never be done outside of a new major release.// Shutdown is called when the SDK shuts down. Any cleanup or release of// resources held by the processor should be done in this call.//// Calls to OnStart, OnEnd, or ForceFlush after this has been called// should be ignored.//// All timeouts and cancellations contained in ctx must be honored, this// should not block indefinitely.Shutdown(ctx context.Context) error// DO NOT CHANGE: any modification will not be backwards compatible and// must never be done outside of a new major release.// ForceFlush exports all ended spans to the configured Exporter that have not yet// been exported. It should only be called when absolutely necessary, such as when// using a FaaS provider that may suspend the process after an invocation, but before// the Processor can export the completed spans.ForceFlush(ctx context.Context) error// DO NOT CHANGE: any modification will not be backwards compatible and// must never be done outside of a new major release.}type spanProcessorState struct {sp SpanProcessorstate sync.Once}func newSpanProcessorState( SpanProcessor) *spanProcessorState {return &spanProcessorState{sp: }}type spanProcessorStates []*spanProcessorState
![]() |
The pages are generated with Golds v0.8.2. (GOOS=linux GOARCH=amd64) Golds is a Go 101 project developed by Tapir Liu. PR and bug reports are welcome and can be submitted to the issue list. Please follow @zigo_101 (reachable from the left QR code) to get the latest news of Golds. |