2020-03-24 07:41:10 +02:00
|
|
|
// Copyright The OpenTelemetry Authors
|
2019-06-14 22:09:41 +02:00
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
|
2020-11-12 17:28:32 +02:00
|
|
|
package metric // import "go.opentelemetry.io/otel/metric"
|
2019-06-14 20:37:05 +02:00
|
|
|
|
|
|
|
import (
|
2019-07-12 00:28:38 +02:00
|
|
|
"context"
|
|
|
|
|
2021-02-18 19:59:37 +02:00
|
|
|
"go.opentelemetry.io/otel/attribute"
|
2020-11-11 17:24:12 +02:00
|
|
|
"go.opentelemetry.io/otel/metric/number"
|
2021-08-12 01:02:28 +02:00
|
|
|
"go.opentelemetry.io/otel/metric/sdkapi"
|
2019-06-14 20:37:05 +02:00
|
|
|
)
|
|
|
|
|
2020-09-24 00:16:13 +02:00
|
|
|
// MeterProvider supports named Meter instances.
|
|
|
|
type MeterProvider interface {
|
2020-06-12 18:11:17 +02:00
|
|
|
// Meter creates an implementation of the Meter interface.
|
|
|
|
// The instrumentationName must be the name of the library providing
|
|
|
|
// instrumentation. This name may be the same as the instrumented code
|
|
|
|
// only if that code provides built-in instrumentation. If the
|
|
|
|
// instrumentationName is empty, then a implementation defined default
|
|
|
|
// name will be used instead.
|
|
|
|
Meter(instrumentationName string, opts ...MeterOption) Meter
|
2019-10-31 08:35:02 +02:00
|
|
|
}
|
|
|
|
|
2020-10-17 18:48:21 +02:00
|
|
|
// Meter is the creator of metric instruments.
|
2020-05-12 05:29:06 +02:00
|
|
|
//
|
|
|
|
// An uninitialized Meter is a no-op implementation.
|
|
|
|
type Meter struct {
|
2021-10-14 18:06:22 +02:00
|
|
|
impl sdkapi.MeterImpl
|
2020-05-12 05:29:06 +02:00
|
|
|
}
|
|
|
|
|
2021-10-14 18:06:22 +02:00
|
|
|
// WrapMeterImpl constructs a `Meter` implementation from a
|
|
|
|
// `MeterImpl` implementation.
|
|
|
|
func WrapMeterImpl(impl sdkapi.MeterImpl) Meter {
|
|
|
|
return Meter{
|
|
|
|
impl: impl,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Measurement is used for reporting a synchronous batch of metric
|
|
|
|
// values. Instances of this type should be created by synchronous
|
|
|
|
// instruments (e.g., Int64Counter.Measurement()).
|
|
|
|
//
|
|
|
|
// Note: This is an alias because it is a first-class member of the
|
|
|
|
// API but is also part of the lower-level sdkapi interface.
|
|
|
|
type Measurement = sdkapi.Measurement
|
|
|
|
|
|
|
|
// Observation is used for reporting an asynchronous batch of metric
|
|
|
|
// values. Instances of this type should be created by asynchronous
|
|
|
|
// instruments (e.g., Int64GaugeObserver.Observation()).
|
|
|
|
//
|
|
|
|
// Note: This is an alias because it is a first-class member of the
|
|
|
|
// API but is also part of the lower-level sdkapi interface.
|
|
|
|
type Observation = sdkapi.Observation
|
|
|
|
|
2020-05-12 05:29:06 +02:00
|
|
|
// RecordBatch atomically records a batch of measurements.
|
2021-02-18 19:59:37 +02:00
|
|
|
func (m Meter) RecordBatch(ctx context.Context, ls []attribute.KeyValue, ms ...Measurement) {
|
2020-05-12 05:29:06 +02:00
|
|
|
if m.impl == nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
m.impl.RecordBatch(ctx, ls, ms...)
|
|
|
|
}
|
|
|
|
|
2020-05-14 22:10:48 +02:00
|
|
|
// NewBatchObserver creates a new BatchObserver that supports
|
|
|
|
// making batches of observations for multiple instruments.
|
2020-08-15 05:56:19 +02:00
|
|
|
func (m Meter) NewBatchObserver(callback BatchObserverFunc) BatchObserver {
|
2020-05-14 22:10:48 +02:00
|
|
|
return BatchObserver{
|
|
|
|
meter: m,
|
|
|
|
runner: newBatchAsyncRunner(callback),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-05-12 05:29:06 +02:00
|
|
|
// NewInt64Counter creates a new integer Counter instrument with the
|
|
|
|
// given name, customized with options. May return an error if the
|
|
|
|
// name is invalid (e.g., empty) or improperly registered (e.g.,
|
|
|
|
// duplicate registration).
|
2020-06-12 18:11:17 +02:00
|
|
|
func (m Meter) NewInt64Counter(name string, options ...InstrumentOption) (Int64Counter, error) {
|
2020-05-12 05:29:06 +02:00
|
|
|
return wrapInt64CounterInstrument(
|
2021-08-12 01:02:28 +02:00
|
|
|
m.newSync(name, sdkapi.CounterInstrumentKind, number.Int64Kind, options))
|
2020-05-12 05:29:06 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// NewFloat64Counter creates a new floating point Counter with the
|
|
|
|
// given name, customized with options. May return an error if the
|
|
|
|
// name is invalid (e.g., empty) or improperly registered (e.g.,
|
|
|
|
// duplicate registration).
|
2020-06-12 18:11:17 +02:00
|
|
|
func (m Meter) NewFloat64Counter(name string, options ...InstrumentOption) (Float64Counter, error) {
|
2020-05-12 05:29:06 +02:00
|
|
|
return wrapFloat64CounterInstrument(
|
2021-08-12 01:02:28 +02:00
|
|
|
m.newSync(name, sdkapi.CounterInstrumentKind, number.Float64Kind, options))
|
2020-05-12 05:29:06 +02:00
|
|
|
}
|
|
|
|
|
2020-05-19 19:00:22 +02:00
|
|
|
// NewInt64UpDownCounter creates a new integer UpDownCounter instrument with the
|
|
|
|
// given name, customized with options. May return an error if the
|
|
|
|
// name is invalid (e.g., empty) or improperly registered (e.g.,
|
|
|
|
// duplicate registration).
|
2020-06-12 18:11:17 +02:00
|
|
|
func (m Meter) NewInt64UpDownCounter(name string, options ...InstrumentOption) (Int64UpDownCounter, error) {
|
2020-05-19 19:00:22 +02:00
|
|
|
return wrapInt64UpDownCounterInstrument(
|
2021-08-12 01:02:28 +02:00
|
|
|
m.newSync(name, sdkapi.UpDownCounterInstrumentKind, number.Int64Kind, options))
|
2020-05-19 19:00:22 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// NewFloat64UpDownCounter creates a new floating point UpDownCounter with the
|
|
|
|
// given name, customized with options. May return an error if the
|
|
|
|
// name is invalid (e.g., empty) or improperly registered (e.g.,
|
|
|
|
// duplicate registration).
|
2020-06-12 18:11:17 +02:00
|
|
|
func (m Meter) NewFloat64UpDownCounter(name string, options ...InstrumentOption) (Float64UpDownCounter, error) {
|
2020-05-19 19:00:22 +02:00
|
|
|
return wrapFloat64UpDownCounterInstrument(
|
2021-08-12 01:02:28 +02:00
|
|
|
m.newSync(name, sdkapi.UpDownCounterInstrumentKind, number.Float64Kind, options))
|
2020-05-19 19:00:22 +02:00
|
|
|
}
|
|
|
|
|
2021-09-01 22:38:37 +02:00
|
|
|
// NewInt64Histogram creates a new integer Histogram instrument with the
|
2020-05-12 05:29:06 +02:00
|
|
|
// given name, customized with options. May return an error if the
|
|
|
|
// name is invalid (e.g., empty) or improperly registered (e.g.,
|
|
|
|
// duplicate registration).
|
2021-09-01 22:38:37 +02:00
|
|
|
func (m Meter) NewInt64Histogram(name string, opts ...InstrumentOption) (Int64Histogram, error) {
|
|
|
|
return wrapInt64HistogramInstrument(
|
|
|
|
m.newSync(name, sdkapi.HistogramInstrumentKind, number.Int64Kind, opts))
|
2020-05-12 05:29:06 +02:00
|
|
|
}
|
|
|
|
|
2021-09-01 22:38:37 +02:00
|
|
|
// NewFloat64Histogram creates a new floating point Histogram with the
|
2020-05-12 05:29:06 +02:00
|
|
|
// given name, customized with options. May return an error if the
|
|
|
|
// name is invalid (e.g., empty) or improperly registered (e.g.,
|
|
|
|
// duplicate registration).
|
2021-09-01 22:38:37 +02:00
|
|
|
func (m Meter) NewFloat64Histogram(name string, opts ...InstrumentOption) (Float64Histogram, error) {
|
|
|
|
return wrapFloat64HistogramInstrument(
|
|
|
|
m.newSync(name, sdkapi.HistogramInstrumentKind, number.Float64Kind, opts))
|
2020-05-12 05:29:06 +02:00
|
|
|
}
|
|
|
|
|
2021-09-01 22:38:37 +02:00
|
|
|
// NewInt64GaugeObserver creates a new integer GaugeObserver instrument
|
2020-05-12 05:29:06 +02:00
|
|
|
// with the given name, running a given callback, and customized with
|
|
|
|
// options. May return an error if the name is invalid (e.g., empty)
|
|
|
|
// or improperly registered (e.g., duplicate registration).
|
2021-09-01 22:38:37 +02:00
|
|
|
func (m Meter) NewInt64GaugeObserver(name string, callback Int64ObserverFunc, opts ...InstrumentOption) (Int64GaugeObserver, error) {
|
2020-05-12 05:29:06 +02:00
|
|
|
if callback == nil {
|
2021-10-14 18:06:22 +02:00
|
|
|
return wrapInt64GaugeObserverInstrument(sdkapi.NewNoopAsyncInstrument(), nil)
|
2020-05-12 05:29:06 +02:00
|
|
|
}
|
2021-09-01 22:38:37 +02:00
|
|
|
return wrapInt64GaugeObserverInstrument(
|
|
|
|
m.newAsync(name, sdkapi.GaugeObserverInstrumentKind, number.Int64Kind, opts,
|
2020-05-14 01:27:52 +02:00
|
|
|
newInt64AsyncRunner(callback)))
|
2020-05-12 05:29:06 +02:00
|
|
|
}
|
|
|
|
|
2021-09-01 22:38:37 +02:00
|
|
|
// NewFloat64GaugeObserver creates a new floating point GaugeObserver with
|
2020-05-12 05:29:06 +02:00
|
|
|
// the given name, running a given callback, and customized with
|
|
|
|
// options. May return an error if the name is invalid (e.g., empty)
|
|
|
|
// or improperly registered (e.g., duplicate registration).
|
2021-09-01 22:38:37 +02:00
|
|
|
func (m Meter) NewFloat64GaugeObserver(name string, callback Float64ObserverFunc, opts ...InstrumentOption) (Float64GaugeObserver, error) {
|
2020-05-12 05:29:06 +02:00
|
|
|
if callback == nil {
|
2021-10-14 18:06:22 +02:00
|
|
|
return wrapFloat64GaugeObserverInstrument(sdkapi.NewNoopAsyncInstrument(), nil)
|
2020-05-12 05:29:06 +02:00
|
|
|
}
|
2021-09-01 22:38:37 +02:00
|
|
|
return wrapFloat64GaugeObserverInstrument(
|
|
|
|
m.newAsync(name, sdkapi.GaugeObserverInstrumentKind, number.Float64Kind, opts,
|
2020-05-14 01:27:52 +02:00
|
|
|
newFloat64AsyncRunner(callback)))
|
2020-05-12 05:29:06 +02:00
|
|
|
}
|
|
|
|
|
2021-09-01 22:38:37 +02:00
|
|
|
// NewInt64CounterObserver creates a new integer CounterObserver instrument
|
2020-05-19 20:49:24 +02:00
|
|
|
// with the given name, running a given callback, and customized with
|
|
|
|
// options. May return an error if the name is invalid (e.g., empty)
|
|
|
|
// or improperly registered (e.g., duplicate registration).
|
2021-09-01 22:38:37 +02:00
|
|
|
func (m Meter) NewInt64CounterObserver(name string, callback Int64ObserverFunc, opts ...InstrumentOption) (Int64CounterObserver, error) {
|
2020-05-19 20:49:24 +02:00
|
|
|
if callback == nil {
|
2021-10-14 18:06:22 +02:00
|
|
|
return wrapInt64CounterObserverInstrument(sdkapi.NewNoopAsyncInstrument(), nil)
|
2020-05-19 20:49:24 +02:00
|
|
|
}
|
2021-09-01 22:38:37 +02:00
|
|
|
return wrapInt64CounterObserverInstrument(
|
|
|
|
m.newAsync(name, sdkapi.CounterObserverInstrumentKind, number.Int64Kind, opts,
|
2020-05-19 20:49:24 +02:00
|
|
|
newInt64AsyncRunner(callback)))
|
|
|
|
}
|
|
|
|
|
2021-09-01 22:38:37 +02:00
|
|
|
// NewFloat64CounterObserver creates a new floating point CounterObserver with
|
2020-05-19 20:49:24 +02:00
|
|
|
// the given name, running a given callback, and customized with
|
|
|
|
// options. May return an error if the name is invalid (e.g., empty)
|
|
|
|
// or improperly registered (e.g., duplicate registration).
|
2021-09-01 22:38:37 +02:00
|
|
|
func (m Meter) NewFloat64CounterObserver(name string, callback Float64ObserverFunc, opts ...InstrumentOption) (Float64CounterObserver, error) {
|
2020-05-19 20:49:24 +02:00
|
|
|
if callback == nil {
|
2021-10-14 18:06:22 +02:00
|
|
|
return wrapFloat64CounterObserverInstrument(sdkapi.NewNoopAsyncInstrument(), nil)
|
2020-05-19 20:49:24 +02:00
|
|
|
}
|
2021-09-01 22:38:37 +02:00
|
|
|
return wrapFloat64CounterObserverInstrument(
|
|
|
|
m.newAsync(name, sdkapi.CounterObserverInstrumentKind, number.Float64Kind, opts,
|
2020-05-19 20:49:24 +02:00
|
|
|
newFloat64AsyncRunner(callback)))
|
|
|
|
}
|
|
|
|
|
2021-09-01 22:38:37 +02:00
|
|
|
// NewInt64UpDownCounterObserver creates a new integer UpDownCounterObserver instrument
|
2020-05-20 19:19:51 +02:00
|
|
|
// with the given name, running a given callback, and customized with
|
|
|
|
// options. May return an error if the name is invalid (e.g., empty)
|
|
|
|
// or improperly registered (e.g., duplicate registration).
|
2021-09-01 22:38:37 +02:00
|
|
|
func (m Meter) NewInt64UpDownCounterObserver(name string, callback Int64ObserverFunc, opts ...InstrumentOption) (Int64UpDownCounterObserver, error) {
|
2020-05-20 19:19:51 +02:00
|
|
|
if callback == nil {
|
2021-10-14 18:06:22 +02:00
|
|
|
return wrapInt64UpDownCounterObserverInstrument(sdkapi.NewNoopAsyncInstrument(), nil)
|
2020-05-20 19:19:51 +02:00
|
|
|
}
|
2021-09-01 22:38:37 +02:00
|
|
|
return wrapInt64UpDownCounterObserverInstrument(
|
|
|
|
m.newAsync(name, sdkapi.UpDownCounterObserverInstrumentKind, number.Int64Kind, opts,
|
2020-05-20 19:19:51 +02:00
|
|
|
newInt64AsyncRunner(callback)))
|
|
|
|
}
|
|
|
|
|
2021-09-01 22:38:37 +02:00
|
|
|
// NewFloat64UpDownCounterObserver creates a new floating point UpDownCounterObserver with
|
2020-05-20 19:19:51 +02:00
|
|
|
// the given name, running a given callback, and customized with
|
|
|
|
// options. May return an error if the name is invalid (e.g., empty)
|
|
|
|
// or improperly registered (e.g., duplicate registration).
|
2021-09-01 22:38:37 +02:00
|
|
|
func (m Meter) NewFloat64UpDownCounterObserver(name string, callback Float64ObserverFunc, opts ...InstrumentOption) (Float64UpDownCounterObserver, error) {
|
2020-05-20 19:19:51 +02:00
|
|
|
if callback == nil {
|
2021-10-14 18:06:22 +02:00
|
|
|
return wrapFloat64UpDownCounterObserverInstrument(sdkapi.NewNoopAsyncInstrument(), nil)
|
2020-05-20 19:19:51 +02:00
|
|
|
}
|
2021-09-01 22:38:37 +02:00
|
|
|
return wrapFloat64UpDownCounterObserverInstrument(
|
|
|
|
m.newAsync(name, sdkapi.UpDownCounterObserverInstrumentKind, number.Float64Kind, opts,
|
2020-05-20 19:19:51 +02:00
|
|
|
newFloat64AsyncRunner(callback)))
|
|
|
|
}
|
|
|
|
|
2021-09-01 22:38:37 +02:00
|
|
|
// NewInt64GaugeObserver creates a new integer GaugeObserver instrument
|
2020-05-14 22:10:48 +02:00
|
|
|
// with the given name, running in a batch callback, and customized with
|
|
|
|
// options. May return an error if the name is invalid (e.g., empty)
|
|
|
|
// or improperly registered (e.g., duplicate registration).
|
2021-09-01 22:38:37 +02:00
|
|
|
func (b BatchObserver) NewInt64GaugeObserver(name string, opts ...InstrumentOption) (Int64GaugeObserver, error) {
|
2020-05-14 22:10:48 +02:00
|
|
|
if b.runner == nil {
|
2021-10-14 18:06:22 +02:00
|
|
|
return wrapInt64GaugeObserverInstrument(sdkapi.NewNoopAsyncInstrument(), nil)
|
2020-05-14 01:27:52 +02:00
|
|
|
}
|
2021-09-01 22:38:37 +02:00
|
|
|
return wrapInt64GaugeObserverInstrument(
|
|
|
|
b.meter.newAsync(name, sdkapi.GaugeObserverInstrumentKind, number.Int64Kind, opts, b.runner))
|
2019-10-23 08:29:24 +02:00
|
|
|
}
|
2019-10-09 00:45:49 +02:00
|
|
|
|
2021-09-01 22:38:37 +02:00
|
|
|
// NewFloat64GaugeObserver creates a new floating point GaugeObserver with
|
2020-05-14 22:10:48 +02:00
|
|
|
// the given name, running in a batch callback, and customized with
|
|
|
|
// options. May return an error if the name is invalid (e.g., empty)
|
|
|
|
// or improperly registered (e.g., duplicate registration).
|
2021-09-01 22:38:37 +02:00
|
|
|
func (b BatchObserver) NewFloat64GaugeObserver(name string, opts ...InstrumentOption) (Float64GaugeObserver, error) {
|
2020-05-14 22:10:48 +02:00
|
|
|
if b.runner == nil {
|
2021-10-14 18:06:22 +02:00
|
|
|
return wrapFloat64GaugeObserverInstrument(sdkapi.NewNoopAsyncInstrument(), nil)
|
2020-05-14 22:10:48 +02:00
|
|
|
}
|
2021-09-01 22:38:37 +02:00
|
|
|
return wrapFloat64GaugeObserverInstrument(
|
|
|
|
b.meter.newAsync(name, sdkapi.GaugeObserverInstrumentKind, number.Float64Kind, opts,
|
2020-05-14 22:10:48 +02:00
|
|
|
b.runner))
|
|
|
|
}
|
|
|
|
|
2021-09-01 22:38:37 +02:00
|
|
|
// NewInt64CounterObserver creates a new integer CounterObserver instrument
|
2020-05-19 20:49:24 +02:00
|
|
|
// with the given name, running in a batch callback, and customized with
|
|
|
|
// options. May return an error if the name is invalid (e.g., empty)
|
|
|
|
// or improperly registered (e.g., duplicate registration).
|
2021-09-01 22:38:37 +02:00
|
|
|
func (b BatchObserver) NewInt64CounterObserver(name string, opts ...InstrumentOption) (Int64CounterObserver, error) {
|
2020-05-19 20:49:24 +02:00
|
|
|
if b.runner == nil {
|
2021-10-14 18:06:22 +02:00
|
|
|
return wrapInt64CounterObserverInstrument(sdkapi.NewNoopAsyncInstrument(), nil)
|
2020-05-19 20:49:24 +02:00
|
|
|
}
|
2021-09-01 22:38:37 +02:00
|
|
|
return wrapInt64CounterObserverInstrument(
|
|
|
|
b.meter.newAsync(name, sdkapi.CounterObserverInstrumentKind, number.Int64Kind, opts, b.runner))
|
2020-05-19 20:49:24 +02:00
|
|
|
}
|
|
|
|
|
2021-09-01 22:38:37 +02:00
|
|
|
// NewFloat64CounterObserver creates a new floating point CounterObserver with
|
2020-05-19 20:49:24 +02:00
|
|
|
// the given name, running in a batch callback, and customized with
|
|
|
|
// options. May return an error if the name is invalid (e.g., empty)
|
|
|
|
// or improperly registered (e.g., duplicate registration).
|
2021-09-01 22:38:37 +02:00
|
|
|
func (b BatchObserver) NewFloat64CounterObserver(name string, opts ...InstrumentOption) (Float64CounterObserver, error) {
|
2020-05-19 20:49:24 +02:00
|
|
|
if b.runner == nil {
|
2021-10-14 18:06:22 +02:00
|
|
|
return wrapFloat64CounterObserverInstrument(sdkapi.NewNoopAsyncInstrument(), nil)
|
2020-05-19 20:49:24 +02:00
|
|
|
}
|
2021-09-01 22:38:37 +02:00
|
|
|
return wrapFloat64CounterObserverInstrument(
|
|
|
|
b.meter.newAsync(name, sdkapi.CounterObserverInstrumentKind, number.Float64Kind, opts,
|
2020-05-19 20:49:24 +02:00
|
|
|
b.runner))
|
|
|
|
}
|
|
|
|
|
2021-09-01 22:38:37 +02:00
|
|
|
// NewInt64UpDownCounterObserver creates a new integer UpDownCounterObserver instrument
|
2020-05-20 19:19:51 +02:00
|
|
|
// with the given name, running in a batch callback, and customized with
|
|
|
|
// options. May return an error if the name is invalid (e.g., empty)
|
|
|
|
// or improperly registered (e.g., duplicate registration).
|
2021-09-01 22:38:37 +02:00
|
|
|
func (b BatchObserver) NewInt64UpDownCounterObserver(name string, opts ...InstrumentOption) (Int64UpDownCounterObserver, error) {
|
2020-05-20 19:19:51 +02:00
|
|
|
if b.runner == nil {
|
2021-10-14 18:06:22 +02:00
|
|
|
return wrapInt64UpDownCounterObserverInstrument(sdkapi.NewNoopAsyncInstrument(), nil)
|
2020-05-20 19:19:51 +02:00
|
|
|
}
|
2021-09-01 22:38:37 +02:00
|
|
|
return wrapInt64UpDownCounterObserverInstrument(
|
|
|
|
b.meter.newAsync(name, sdkapi.UpDownCounterObserverInstrumentKind, number.Int64Kind, opts, b.runner))
|
2020-05-20 19:19:51 +02:00
|
|
|
}
|
|
|
|
|
2021-09-01 22:38:37 +02:00
|
|
|
// NewFloat64UpDownCounterObserver creates a new floating point UpDownCounterObserver with
|
2020-05-20 19:19:51 +02:00
|
|
|
// the given name, running in a batch callback, and customized with
|
|
|
|
// options. May return an error if the name is invalid (e.g., empty)
|
|
|
|
// or improperly registered (e.g., duplicate registration).
|
2021-09-01 22:38:37 +02:00
|
|
|
func (b BatchObserver) NewFloat64UpDownCounterObserver(name string, opts ...InstrumentOption) (Float64UpDownCounterObserver, error) {
|
2020-05-20 19:19:51 +02:00
|
|
|
if b.runner == nil {
|
2021-10-14 18:06:22 +02:00
|
|
|
return wrapFloat64UpDownCounterObserverInstrument(sdkapi.NewNoopAsyncInstrument(), nil)
|
2020-05-20 19:19:51 +02:00
|
|
|
}
|
2021-09-01 22:38:37 +02:00
|
|
|
return wrapFloat64UpDownCounterObserverInstrument(
|
|
|
|
b.meter.newAsync(name, sdkapi.UpDownCounterObserverInstrumentKind, number.Float64Kind, opts,
|
2020-05-20 19:19:51 +02:00
|
|
|
b.runner))
|
|
|
|
}
|
|
|
|
|
2020-05-14 22:10:48 +02:00
|
|
|
// MeterImpl returns the underlying MeterImpl of this Meter.
|
2021-10-14 18:06:22 +02:00
|
|
|
func (m Meter) MeterImpl() sdkapi.MeterImpl {
|
2020-05-14 22:10:48 +02:00
|
|
|
return m.impl
|
|
|
|
}
|
|
|
|
|
|
|
|
// newAsync constructs one new asynchronous instrument.
|
|
|
|
func (m Meter) newAsync(
|
|
|
|
name string,
|
2021-08-12 01:02:28 +02:00
|
|
|
mkind sdkapi.InstrumentKind,
|
2020-11-11 17:24:12 +02:00
|
|
|
nkind number.Kind,
|
2020-06-12 18:11:17 +02:00
|
|
|
opts []InstrumentOption,
|
2021-10-14 18:06:22 +02:00
|
|
|
runner sdkapi.AsyncRunner,
|
2020-05-14 22:10:48 +02:00
|
|
|
) (
|
2021-10-14 18:06:22 +02:00
|
|
|
sdkapi.AsyncImpl,
|
2020-05-14 22:10:48 +02:00
|
|
|
error,
|
|
|
|
) {
|
|
|
|
if m.impl == nil {
|
2021-10-14 18:06:22 +02:00
|
|
|
return sdkapi.NewNoopAsyncInstrument(), nil
|
2020-05-14 22:10:48 +02:00
|
|
|
}
|
2021-09-27 17:51:47 +02:00
|
|
|
cfg := NewInstrumentConfig(opts...)
|
2021-10-14 18:06:22 +02:00
|
|
|
desc := sdkapi.NewDescriptor(name, mkind, nkind, cfg.description, cfg.unit)
|
2020-05-14 22:10:48 +02:00
|
|
|
return m.impl.NewAsyncInstrument(desc, runner)
|
|
|
|
}
|
|
|
|
|
|
|
|
// newSync constructs one new synchronous instrument.
|
|
|
|
func (m Meter) newSync(
|
|
|
|
name string,
|
2021-08-12 01:02:28 +02:00
|
|
|
metricKind sdkapi.InstrumentKind,
|
2020-11-11 17:24:12 +02:00
|
|
|
numberKind number.Kind,
|
2020-06-12 18:11:17 +02:00
|
|
|
opts []InstrumentOption,
|
2020-05-14 22:10:48 +02:00
|
|
|
) (
|
2021-10-14 18:06:22 +02:00
|
|
|
sdkapi.SyncImpl,
|
2020-05-14 22:10:48 +02:00
|
|
|
error,
|
|
|
|
) {
|
|
|
|
if m.impl == nil {
|
2021-10-14 18:06:22 +02:00
|
|
|
return sdkapi.NewNoopSyncInstrument(), nil
|
2020-05-14 22:10:48 +02:00
|
|
|
}
|
2021-09-27 17:51:47 +02:00
|
|
|
cfg := NewInstrumentConfig(opts...)
|
2021-10-14 18:06:22 +02:00
|
|
|
desc := sdkapi.NewDescriptor(name, metricKind, numberKind, cfg.description, cfg.unit)
|
2020-05-14 22:10:48 +02:00
|
|
|
return m.impl.NewSyncInstrument(desc)
|
2020-03-24 19:54:08 +02:00
|
|
|
}
|
2020-10-17 18:48:21 +02:00
|
|
|
|
|
|
|
// MeterMust is a wrapper for Meter interfaces that panics when any
|
|
|
|
// instrument constructor encounters an error.
|
|
|
|
type MeterMust struct {
|
|
|
|
meter Meter
|
|
|
|
}
|
|
|
|
|
|
|
|
// BatchObserverMust is a wrapper for BatchObserver that panics when
|
|
|
|
// any instrument constructor encounters an error.
|
|
|
|
type BatchObserverMust struct {
|
|
|
|
batch BatchObserver
|
|
|
|
}
|
|
|
|
|
|
|
|
// Must constructs a MeterMust implementation from a Meter, allowing
|
|
|
|
// the application to panic when any instrument constructor yields an
|
|
|
|
// error.
|
|
|
|
func Must(meter Meter) MeterMust {
|
|
|
|
return MeterMust{meter: meter}
|
|
|
|
}
|
|
|
|
|
|
|
|
// NewInt64Counter calls `Meter.NewInt64Counter` and returns the
|
|
|
|
// instrument, panicking if it encounters an error.
|
|
|
|
func (mm MeterMust) NewInt64Counter(name string, cos ...InstrumentOption) Int64Counter {
|
|
|
|
if inst, err := mm.meter.NewInt64Counter(name, cos...); err != nil {
|
|
|
|
panic(err)
|
|
|
|
} else {
|
|
|
|
return inst
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// NewFloat64Counter calls `Meter.NewFloat64Counter` and returns the
|
|
|
|
// instrument, panicking if it encounters an error.
|
|
|
|
func (mm MeterMust) NewFloat64Counter(name string, cos ...InstrumentOption) Float64Counter {
|
|
|
|
if inst, err := mm.meter.NewFloat64Counter(name, cos...); err != nil {
|
|
|
|
panic(err)
|
|
|
|
} else {
|
|
|
|
return inst
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// NewInt64UpDownCounter calls `Meter.NewInt64UpDownCounter` and returns the
|
|
|
|
// instrument, panicking if it encounters an error.
|
|
|
|
func (mm MeterMust) NewInt64UpDownCounter(name string, cos ...InstrumentOption) Int64UpDownCounter {
|
|
|
|
if inst, err := mm.meter.NewInt64UpDownCounter(name, cos...); err != nil {
|
|
|
|
panic(err)
|
|
|
|
} else {
|
|
|
|
return inst
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// NewFloat64UpDownCounter calls `Meter.NewFloat64UpDownCounter` and returns the
|
|
|
|
// instrument, panicking if it encounters an error.
|
|
|
|
func (mm MeterMust) NewFloat64UpDownCounter(name string, cos ...InstrumentOption) Float64UpDownCounter {
|
|
|
|
if inst, err := mm.meter.NewFloat64UpDownCounter(name, cos...); err != nil {
|
|
|
|
panic(err)
|
|
|
|
} else {
|
|
|
|
return inst
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-09-01 22:38:37 +02:00
|
|
|
// NewInt64Histogram calls `Meter.NewInt64Histogram` and returns the
|
2020-10-17 18:48:21 +02:00
|
|
|
// instrument, panicking if it encounters an error.
|
2021-09-01 22:38:37 +02:00
|
|
|
func (mm MeterMust) NewInt64Histogram(name string, mos ...InstrumentOption) Int64Histogram {
|
|
|
|
if inst, err := mm.meter.NewInt64Histogram(name, mos...); err != nil {
|
2020-10-17 18:48:21 +02:00
|
|
|
panic(err)
|
|
|
|
} else {
|
|
|
|
return inst
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-09-01 22:38:37 +02:00
|
|
|
// NewFloat64Histogram calls `Meter.NewFloat64Histogram` and returns the
|
2020-10-17 18:48:21 +02:00
|
|
|
// instrument, panicking if it encounters an error.
|
2021-09-01 22:38:37 +02:00
|
|
|
func (mm MeterMust) NewFloat64Histogram(name string, mos ...InstrumentOption) Float64Histogram {
|
|
|
|
if inst, err := mm.meter.NewFloat64Histogram(name, mos...); err != nil {
|
2020-10-17 18:48:21 +02:00
|
|
|
panic(err)
|
|
|
|
} else {
|
|
|
|
return inst
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-09-01 22:38:37 +02:00
|
|
|
// NewInt64GaugeObserver calls `Meter.NewInt64GaugeObserver` and
|
2020-10-17 18:48:21 +02:00
|
|
|
// returns the instrument, panicking if it encounters an error.
|
2021-09-01 22:38:37 +02:00
|
|
|
func (mm MeterMust) NewInt64GaugeObserver(name string, callback Int64ObserverFunc, oos ...InstrumentOption) Int64GaugeObserver {
|
|
|
|
if inst, err := mm.meter.NewInt64GaugeObserver(name, callback, oos...); err != nil {
|
2020-10-17 18:48:21 +02:00
|
|
|
panic(err)
|
|
|
|
} else {
|
|
|
|
return inst
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-09-01 22:38:37 +02:00
|
|
|
// NewFloat64GaugeObserver calls `Meter.NewFloat64GaugeObserver` and
|
2020-10-17 18:48:21 +02:00
|
|
|
// returns the instrument, panicking if it encounters an error.
|
2021-09-01 22:38:37 +02:00
|
|
|
func (mm MeterMust) NewFloat64GaugeObserver(name string, callback Float64ObserverFunc, oos ...InstrumentOption) Float64GaugeObserver {
|
|
|
|
if inst, err := mm.meter.NewFloat64GaugeObserver(name, callback, oos...); err != nil {
|
2020-10-17 18:48:21 +02:00
|
|
|
panic(err)
|
|
|
|
} else {
|
|
|
|
return inst
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-09-01 22:38:37 +02:00
|
|
|
// NewInt64CounterObserver calls `Meter.NewInt64CounterObserver` and
|
2020-10-17 18:48:21 +02:00
|
|
|
// returns the instrument, panicking if it encounters an error.
|
2021-09-01 22:38:37 +02:00
|
|
|
func (mm MeterMust) NewInt64CounterObserver(name string, callback Int64ObserverFunc, oos ...InstrumentOption) Int64CounterObserver {
|
|
|
|
if inst, err := mm.meter.NewInt64CounterObserver(name, callback, oos...); err != nil {
|
2020-10-17 18:48:21 +02:00
|
|
|
panic(err)
|
|
|
|
} else {
|
|
|
|
return inst
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-09-01 22:38:37 +02:00
|
|
|
// NewFloat64CounterObserver calls `Meter.NewFloat64CounterObserver` and
|
2020-10-17 18:48:21 +02:00
|
|
|
// returns the instrument, panicking if it encounters an error.
|
2021-09-01 22:38:37 +02:00
|
|
|
func (mm MeterMust) NewFloat64CounterObserver(name string, callback Float64ObserverFunc, oos ...InstrumentOption) Float64CounterObserver {
|
|
|
|
if inst, err := mm.meter.NewFloat64CounterObserver(name, callback, oos...); err != nil {
|
2020-10-17 18:48:21 +02:00
|
|
|
panic(err)
|
|
|
|
} else {
|
|
|
|
return inst
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-09-01 22:38:37 +02:00
|
|
|
// NewInt64UpDownCounterObserver calls `Meter.NewInt64UpDownCounterObserver` and
|
2020-10-17 18:48:21 +02:00
|
|
|
// returns the instrument, panicking if it encounters an error.
|
2021-09-01 22:38:37 +02:00
|
|
|
func (mm MeterMust) NewInt64UpDownCounterObserver(name string, callback Int64ObserverFunc, oos ...InstrumentOption) Int64UpDownCounterObserver {
|
|
|
|
if inst, err := mm.meter.NewInt64UpDownCounterObserver(name, callback, oos...); err != nil {
|
2020-10-17 18:48:21 +02:00
|
|
|
panic(err)
|
|
|
|
} else {
|
|
|
|
return inst
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-09-01 22:38:37 +02:00
|
|
|
// NewFloat64UpDownCounterObserver calls `Meter.NewFloat64UpDownCounterObserver` and
|
2020-10-17 18:48:21 +02:00
|
|
|
// returns the instrument, panicking if it encounters an error.
|
2021-09-01 22:38:37 +02:00
|
|
|
func (mm MeterMust) NewFloat64UpDownCounterObserver(name string, callback Float64ObserverFunc, oos ...InstrumentOption) Float64UpDownCounterObserver {
|
|
|
|
if inst, err := mm.meter.NewFloat64UpDownCounterObserver(name, callback, oos...); err != nil {
|
2020-10-17 18:48:21 +02:00
|
|
|
panic(err)
|
|
|
|
} else {
|
|
|
|
return inst
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// NewBatchObserver returns a wrapper around BatchObserver that panics
|
|
|
|
// when any instrument constructor returns an error.
|
|
|
|
func (mm MeterMust) NewBatchObserver(callback BatchObserverFunc) BatchObserverMust {
|
|
|
|
return BatchObserverMust{
|
|
|
|
batch: mm.meter.NewBatchObserver(callback),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-09-01 22:38:37 +02:00
|
|
|
// NewInt64GaugeObserver calls `BatchObserver.NewInt64GaugeObserver` and
|
2020-10-17 18:48:21 +02:00
|
|
|
// returns the instrument, panicking if it encounters an error.
|
2021-09-01 22:38:37 +02:00
|
|
|
func (bm BatchObserverMust) NewInt64GaugeObserver(name string, oos ...InstrumentOption) Int64GaugeObserver {
|
|
|
|
if inst, err := bm.batch.NewInt64GaugeObserver(name, oos...); err != nil {
|
2020-10-17 18:48:21 +02:00
|
|
|
panic(err)
|
|
|
|
} else {
|
|
|
|
return inst
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-09-01 22:38:37 +02:00
|
|
|
// NewFloat64GaugeObserver calls `BatchObserver.NewFloat64GaugeObserver` and
|
2020-10-17 18:48:21 +02:00
|
|
|
// returns the instrument, panicking if it encounters an error.
|
2021-09-01 22:38:37 +02:00
|
|
|
func (bm BatchObserverMust) NewFloat64GaugeObserver(name string, oos ...InstrumentOption) Float64GaugeObserver {
|
|
|
|
if inst, err := bm.batch.NewFloat64GaugeObserver(name, oos...); err != nil {
|
2020-10-17 18:48:21 +02:00
|
|
|
panic(err)
|
|
|
|
} else {
|
|
|
|
return inst
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-09-01 22:38:37 +02:00
|
|
|
// NewInt64CounterObserver calls `BatchObserver.NewInt64CounterObserver` and
|
2020-10-17 18:48:21 +02:00
|
|
|
// returns the instrument, panicking if it encounters an error.
|
2021-09-01 22:38:37 +02:00
|
|
|
func (bm BatchObserverMust) NewInt64CounterObserver(name string, oos ...InstrumentOption) Int64CounterObserver {
|
|
|
|
if inst, err := bm.batch.NewInt64CounterObserver(name, oos...); err != nil {
|
2020-10-17 18:48:21 +02:00
|
|
|
panic(err)
|
|
|
|
} else {
|
|
|
|
return inst
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-09-01 22:38:37 +02:00
|
|
|
// NewFloat64CounterObserver calls `BatchObserver.NewFloat64CounterObserver` and
|
2020-10-17 18:48:21 +02:00
|
|
|
// returns the instrument, panicking if it encounters an error.
|
2021-09-01 22:38:37 +02:00
|
|
|
func (bm BatchObserverMust) NewFloat64CounterObserver(name string, oos ...InstrumentOption) Float64CounterObserver {
|
|
|
|
if inst, err := bm.batch.NewFloat64CounterObserver(name, oos...); err != nil {
|
2020-10-17 18:48:21 +02:00
|
|
|
panic(err)
|
|
|
|
} else {
|
|
|
|
return inst
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-09-01 22:38:37 +02:00
|
|
|
// NewInt64UpDownCounterObserver calls `BatchObserver.NewInt64UpDownCounterObserver` and
|
2020-10-17 18:48:21 +02:00
|
|
|
// returns the instrument, panicking if it encounters an error.
|
2021-09-01 22:38:37 +02:00
|
|
|
func (bm BatchObserverMust) NewInt64UpDownCounterObserver(name string, oos ...InstrumentOption) Int64UpDownCounterObserver {
|
|
|
|
if inst, err := bm.batch.NewInt64UpDownCounterObserver(name, oos...); err != nil {
|
2020-10-17 18:48:21 +02:00
|
|
|
panic(err)
|
|
|
|
} else {
|
|
|
|
return inst
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-09-01 22:38:37 +02:00
|
|
|
// NewFloat64UpDownCounterObserver calls `BatchObserver.NewFloat64UpDownCounterObserver` and
|
2020-10-17 18:48:21 +02:00
|
|
|
// returns the instrument, panicking if it encounters an error.
|
2021-09-01 22:38:37 +02:00
|
|
|
func (bm BatchObserverMust) NewFloat64UpDownCounterObserver(name string, oos ...InstrumentOption) Float64UpDownCounterObserver {
|
|
|
|
if inst, err := bm.batch.NewFloat64UpDownCounterObserver(name, oos...); err != nil {
|
2020-10-17 18:48:21 +02:00
|
|
|
panic(err)
|
|
|
|
} else {
|
|
|
|
return inst
|
|
|
|
}
|
|
|
|
}
|