You've already forked opentelemetry-go
mirror of
https://github.com/open-telemetry/opentelemetry-go.git
synced 2026-06-03 18:35:08 +02:00
28df982c8b
Part of https://github.com/open-telemetry/opentelemetry-go/issues/8110 Related to https://github.com/open-telemetry/opentelemetry-go/issues/5882. I'm hoping to find a better way to support experimental Options types in our API packages. This is one approach to consider. This contains no public API changes. It introduces a type: `ExperimentalOption` in `/metric/internal/x`, which can be used by our experimental options defined outside of the module. Options that embed this interface are ignored by `New*Config` builder functions in the metrics API to prevent them from panicing when used. Only SDKs that explicitly support the experimental option in question will respect it. Alternative SDKs will ignore the experimental options. We would still need to treat ExperimentalOption as a stable artifact, since the SDK will indirectly depend on it. See https://github.com/open-telemetry/opentelemetry-go/compare/main...dashpole:opentelemetry-go:attributes_advisory for how this would be used to support the advisory attributes parameter.
287 lines
9.5 KiB
Go
287 lines
9.5 KiB
Go
// Copyright The OpenTelemetry Authors
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
package metric // import "go.opentelemetry.io/otel/metric"
|
|
|
|
import (
|
|
"context"
|
|
|
|
"go.opentelemetry.io/otel/metric/embedded"
|
|
)
|
|
|
|
// Float64Counter is an instrument that records increasing float64 values.
|
|
//
|
|
// Warning: Methods may be added to this interface in minor releases. See
|
|
// package documentation on API implementation for information on how to set
|
|
// default behavior for unimplemented methods.
|
|
type Float64Counter interface {
|
|
// Users of the interface can ignore this. This embedded type is only used
|
|
// by implementations of this interface. See the "API Implementations"
|
|
// section of the package documentation for more information.
|
|
embedded.Float64Counter
|
|
|
|
// Add records a change to the counter.
|
|
//
|
|
// Use the WithAttributeSet (or, if performance is not a concern,
|
|
// the WithAttributes) option to include measurement attributes.
|
|
//
|
|
// Implementations of this method need to be safe for a user to call
|
|
// concurrently.
|
|
Add(ctx context.Context, incr float64, options ...AddOption)
|
|
|
|
// Enabled reports whether the instrument will process measurements for the given context.
|
|
//
|
|
// This function can be used in places where measuring an instrument
|
|
// would result in computationally expensive operations.
|
|
//
|
|
// Implementations of this method need to be safe for a user to call
|
|
// concurrently.
|
|
Enabled(context.Context) bool
|
|
}
|
|
|
|
// Float64CounterConfig contains options for synchronous counter instruments that
|
|
// record float64 values.
|
|
type Float64CounterConfig struct {
|
|
description string
|
|
unit string
|
|
}
|
|
|
|
// NewFloat64CounterConfig returns a new [Float64CounterConfig] with all opts
|
|
// applied.
|
|
func NewFloat64CounterConfig(opts ...Float64CounterOption) Float64CounterConfig {
|
|
var config Float64CounterConfig
|
|
for _, o := range opts {
|
|
if _, ok := o.(experimentalOption); ok {
|
|
continue
|
|
}
|
|
config = o.applyFloat64Counter(config)
|
|
}
|
|
return config
|
|
}
|
|
|
|
// Description returns the configured description.
|
|
func (c Float64CounterConfig) Description() string {
|
|
return c.description
|
|
}
|
|
|
|
// Unit returns the configured unit.
|
|
func (c Float64CounterConfig) Unit() string {
|
|
return c.unit
|
|
}
|
|
|
|
// Float64CounterOption applies options to a [Float64CounterConfig]. See
|
|
// [InstrumentOption] for other options that can be used as a
|
|
// Float64CounterOption.
|
|
type Float64CounterOption interface {
|
|
applyFloat64Counter(Float64CounterConfig) Float64CounterConfig
|
|
}
|
|
|
|
// Float64UpDownCounter is an instrument that records increasing or decreasing
|
|
// float64 values.
|
|
//
|
|
// Warning: Methods may be added to this interface in minor releases. See
|
|
// package documentation on API implementation for information on how to set
|
|
// default behavior for unimplemented methods.
|
|
type Float64UpDownCounter interface {
|
|
// Users of the interface can ignore this. This embedded type is only used
|
|
// by implementations of this interface. See the "API Implementations"
|
|
// section of the package documentation for more information.
|
|
embedded.Float64UpDownCounter
|
|
|
|
// Add records a change to the counter.
|
|
//
|
|
// Use the WithAttributeSet (or, if performance is not a concern,
|
|
// the WithAttributes) option to include measurement attributes.
|
|
//
|
|
// Implementations of this method need to be safe for a user to call
|
|
// concurrently.
|
|
Add(ctx context.Context, incr float64, options ...AddOption)
|
|
|
|
// Enabled reports whether the instrument will process measurements for the given context.
|
|
//
|
|
// This function can be used in places where measuring an instrument
|
|
// would result in computationally expensive operations.
|
|
//
|
|
// Implementations of this method need to be safe for a user to call
|
|
// concurrently.
|
|
Enabled(context.Context) bool
|
|
}
|
|
|
|
// Float64UpDownCounterConfig contains options for synchronous counter
|
|
// instruments that record float64 values.
|
|
type Float64UpDownCounterConfig struct {
|
|
description string
|
|
unit string
|
|
}
|
|
|
|
// NewFloat64UpDownCounterConfig returns a new [Float64UpDownCounterConfig]
|
|
// with all opts applied.
|
|
func NewFloat64UpDownCounterConfig(opts ...Float64UpDownCounterOption) Float64UpDownCounterConfig {
|
|
var config Float64UpDownCounterConfig
|
|
for _, o := range opts {
|
|
if _, ok := o.(experimentalOption); ok {
|
|
continue
|
|
}
|
|
config = o.applyFloat64UpDownCounter(config)
|
|
}
|
|
return config
|
|
}
|
|
|
|
// Description returns the configured description.
|
|
func (c Float64UpDownCounterConfig) Description() string {
|
|
return c.description
|
|
}
|
|
|
|
// Unit returns the configured unit.
|
|
func (c Float64UpDownCounterConfig) Unit() string {
|
|
return c.unit
|
|
}
|
|
|
|
// Float64UpDownCounterOption applies options to a
|
|
// [Float64UpDownCounterConfig]. See [InstrumentOption] for other options that
|
|
// can be used as a Float64UpDownCounterOption.
|
|
type Float64UpDownCounterOption interface {
|
|
applyFloat64UpDownCounter(Float64UpDownCounterConfig) Float64UpDownCounterConfig
|
|
}
|
|
|
|
// Float64Histogram is an instrument that records a distribution of float64
|
|
// values.
|
|
//
|
|
// Warning: Methods may be added to this interface in minor releases. See
|
|
// package documentation on API implementation for information on how to set
|
|
// default behavior for unimplemented methods.
|
|
type Float64Histogram interface {
|
|
// Users of the interface can ignore this. This embedded type is only used
|
|
// by implementations of this interface. See the "API Implementations"
|
|
// section of the package documentation for more information.
|
|
embedded.Float64Histogram
|
|
|
|
// Record adds an additional value to the distribution.
|
|
//
|
|
// Use the WithAttributeSet (or, if performance is not a concern,
|
|
// the WithAttributes) option to include measurement attributes.
|
|
//
|
|
// Implementations of this method need to be safe for a user to call
|
|
// concurrently.
|
|
Record(ctx context.Context, incr float64, options ...RecordOption)
|
|
|
|
// Enabled reports whether the instrument will process measurements for the given context.
|
|
//
|
|
// This function can be used in places where measuring an instrument
|
|
// would result in computationally expensive operations.
|
|
//
|
|
// Implementations of this method need to be safe for a user to call
|
|
// concurrently.
|
|
Enabled(context.Context) bool
|
|
}
|
|
|
|
// Float64HistogramConfig contains options for synchronous histogram
|
|
// instruments that record float64 values.
|
|
type Float64HistogramConfig struct {
|
|
description string
|
|
unit string
|
|
explicitBucketBoundaries []float64
|
|
}
|
|
|
|
// NewFloat64HistogramConfig returns a new [Float64HistogramConfig] with all
|
|
// opts applied.
|
|
func NewFloat64HistogramConfig(opts ...Float64HistogramOption) Float64HistogramConfig {
|
|
var config Float64HistogramConfig
|
|
for _, o := range opts {
|
|
if _, ok := o.(experimentalOption); ok {
|
|
continue
|
|
}
|
|
config = o.applyFloat64Histogram(config)
|
|
}
|
|
return config
|
|
}
|
|
|
|
// Description returns the configured description.
|
|
func (c Float64HistogramConfig) Description() string {
|
|
return c.description
|
|
}
|
|
|
|
// Unit returns the configured unit.
|
|
func (c Float64HistogramConfig) Unit() string {
|
|
return c.unit
|
|
}
|
|
|
|
// ExplicitBucketBoundaries returns the configured explicit bucket boundaries.
|
|
func (c Float64HistogramConfig) ExplicitBucketBoundaries() []float64 {
|
|
return c.explicitBucketBoundaries
|
|
}
|
|
|
|
// Float64HistogramOption applies options to a [Float64HistogramConfig]. See
|
|
// [InstrumentOption] for other options that can be used as a
|
|
// Float64HistogramOption.
|
|
type Float64HistogramOption interface {
|
|
applyFloat64Histogram(Float64HistogramConfig) Float64HistogramConfig
|
|
}
|
|
|
|
// Float64Gauge is an instrument that records instantaneous float64 values.
|
|
//
|
|
// Warning: Methods may be added to this interface in minor releases. See
|
|
// package documentation on API implementation for information on how to set
|
|
// default behavior for unimplemented methods.
|
|
type Float64Gauge interface {
|
|
// Users of the interface can ignore this. This embedded type is only used
|
|
// by implementations of this interface. See the "API Implementations"
|
|
// section of the package documentation for more information.
|
|
embedded.Float64Gauge
|
|
|
|
// Record records the instantaneous value.
|
|
//
|
|
// Use the WithAttributeSet (or, if performance is not a concern,
|
|
// the WithAttributes) option to include measurement attributes.
|
|
//
|
|
// Implementations of this method need to be safe for a user to call
|
|
// concurrently.
|
|
Record(ctx context.Context, value float64, options ...RecordOption)
|
|
|
|
// Enabled reports whether the instrument will process measurements for the given context.
|
|
//
|
|
// This function can be used in places where measuring an instrument
|
|
// would result in computationally expensive operations.
|
|
//
|
|
// Implementations of this method need to be safe for a user to call
|
|
// concurrently.
|
|
Enabled(context.Context) bool
|
|
}
|
|
|
|
// Float64GaugeConfig contains options for synchronous gauge instruments that
|
|
// record float64 values.
|
|
type Float64GaugeConfig struct {
|
|
description string
|
|
unit string
|
|
}
|
|
|
|
// NewFloat64GaugeConfig returns a new [Float64GaugeConfig] with all opts
|
|
// applied.
|
|
func NewFloat64GaugeConfig(opts ...Float64GaugeOption) Float64GaugeConfig {
|
|
var config Float64GaugeConfig
|
|
for _, o := range opts {
|
|
if _, ok := o.(experimentalOption); ok {
|
|
continue
|
|
}
|
|
config = o.applyFloat64Gauge(config)
|
|
}
|
|
return config
|
|
}
|
|
|
|
// Description returns the configured description.
|
|
func (c Float64GaugeConfig) Description() string {
|
|
return c.description
|
|
}
|
|
|
|
// Unit returns the configured unit.
|
|
func (c Float64GaugeConfig) Unit() string {
|
|
return c.unit
|
|
}
|
|
|
|
// Float64GaugeOption applies options to a [Float64GaugeConfig]. See
|
|
// [InstrumentOption] for other options that can be used as a
|
|
// Float64GaugeOption.
|
|
type Float64GaugeOption interface {
|
|
applyFloat64Gauge(Float64GaugeConfig) Float64GaugeConfig
|
|
}
|