opentelemetry-collector/processor/processorhelper/internal/metadata/generated_telemetry.go

83 lines
2.6 KiB
Go

// Code generated by mdatagen. DO NOT EDIT.
package metadata
import (
"errors"
"sync"
"go.opentelemetry.io/otel/metric"
"go.opentelemetry.io/otel/trace"
"go.opentelemetry.io/collector/component"
)
func Meter(settings component.TelemetrySettings) metric.Meter {
return settings.MeterProvider.Meter("go.opentelemetry.io/collector/processor/processorhelper")
}
func Tracer(settings component.TelemetrySettings) trace.Tracer {
return settings.TracerProvider.Tracer("go.opentelemetry.io/collector/processor/processorhelper")
}
// TelemetryBuilder provides an interface for components to report telemetry
// as defined in metadata and user config.
type TelemetryBuilder struct {
meter metric.Meter
mu sync.Mutex
registrations []metric.Registration
ProcessorIncomingItems metric.Int64Counter
ProcessorInternalDuration metric.Float64Histogram
ProcessorOutgoingItems metric.Int64Counter
}
// TelemetryBuilderOption applies changes to default builder.
type TelemetryBuilderOption interface {
apply(*TelemetryBuilder)
}
type telemetryBuilderOptionFunc func(mb *TelemetryBuilder)
func (tbof telemetryBuilderOptionFunc) apply(mb *TelemetryBuilder) {
tbof(mb)
}
// Shutdown unregister all registered callbacks for async instruments.
func (builder *TelemetryBuilder) Shutdown() {
builder.mu.Lock()
defer builder.mu.Unlock()
for _, reg := range builder.registrations {
reg.Unregister()
}
}
// NewTelemetryBuilder provides a struct with methods to update all internal telemetry
// for a component
func NewTelemetryBuilder(settings component.TelemetrySettings, options ...TelemetryBuilderOption) (*TelemetryBuilder, error) {
builder := TelemetryBuilder{}
for _, op := range options {
op.apply(&builder)
}
builder.meter = Meter(settings)
var err, errs error
builder.ProcessorIncomingItems, err = builder.meter.Int64Counter(
"otelcol_processor_incoming_items",
metric.WithDescription("Number of items passed to the processor. [alpha]"),
metric.WithUnit("{items}"),
)
errs = errors.Join(errs, err)
builder.ProcessorInternalDuration, err = builder.meter.Float64Histogram(
"otelcol_processor_internal_duration",
metric.WithDescription("Duration of time taken to process a batch of telemetry data through the processor. [alpha]"),
metric.WithUnit("s"),
)
errs = errors.Join(errs, err)
builder.ProcessorOutgoingItems, err = builder.meter.Int64Counter(
"otelcol_processor_outgoing_items",
metric.WithDescription("Number of items emitted from the processor. [alpha]"),
metric.WithUnit("{items}"),
)
errs = errors.Join(errs, err)
return &builder, errs
}