2020-05-14 22:10:48 +02:00
|
|
|
// Copyright The OpenTelemetry Authors
|
|
|
|
//
|
|
|
|
// 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"
|
2020-05-14 22:10:48 +02:00
|
|
|
|
|
|
|
import (
|
|
|
|
"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"
|
2020-05-14 22:10:48 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
// MeterImpl is the interface an SDK must implement to supply a Meter
|
|
|
|
// implementation.
|
|
|
|
type MeterImpl interface {
|
|
|
|
// RecordBatch atomically records a batch of measurements.
|
2021-02-18 19:59:37 +02:00
|
|
|
RecordBatch(ctx context.Context, labels []attribute.KeyValue, measurement ...Measurement)
|
2020-05-14 22:10:48 +02:00
|
|
|
|
|
|
|
// NewSyncInstrument returns a newly constructed
|
|
|
|
// synchronous instrument implementation or an error, should
|
|
|
|
// one occur.
|
|
|
|
NewSyncInstrument(descriptor Descriptor) (SyncImpl, error)
|
|
|
|
|
|
|
|
// NewAsyncInstrument returns a newly constructed
|
|
|
|
// asynchronous instrument implementation or an error, should
|
|
|
|
// one occur.
|
|
|
|
NewAsyncInstrument(
|
|
|
|
descriptor Descriptor,
|
|
|
|
runner AsyncRunner,
|
|
|
|
) (AsyncImpl, error)
|
|
|
|
}
|
|
|
|
|
|
|
|
// InstrumentImpl is a common interface for synchronous and
|
|
|
|
// asynchronous instruments.
|
|
|
|
type InstrumentImpl interface {
|
|
|
|
// Implementation returns the underlying implementation of the
|
|
|
|
// instrument, which allows the implementation to gain access
|
|
|
|
// to its own representation especially from a `Measurement`.
|
|
|
|
Implementation() interface{}
|
|
|
|
|
|
|
|
// Descriptor returns a copy of the instrument's Descriptor.
|
|
|
|
Descriptor() Descriptor
|
|
|
|
}
|
|
|
|
|
|
|
|
// SyncImpl is the implementation-level interface to a generic
|
2020-05-16 07:11:12 +02:00
|
|
|
// synchronous instrument (e.g., ValueRecorder and Counter instruments).
|
2020-05-14 22:10:48 +02:00
|
|
|
type SyncImpl interface {
|
|
|
|
InstrumentImpl
|
|
|
|
|
|
|
|
// Bind creates an implementation-level bound instrument,
|
|
|
|
// binding a label set with this instrument implementation.
|
2021-02-18 19:59:37 +02:00
|
|
|
Bind(labels []attribute.KeyValue) BoundSyncImpl
|
2020-05-14 22:10:48 +02:00
|
|
|
|
|
|
|
// RecordOne captures a single synchronous metric event.
|
2021-02-18 19:59:37 +02:00
|
|
|
RecordOne(ctx context.Context, number number.Number, labels []attribute.KeyValue)
|
2020-05-14 22:10:48 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// BoundSyncImpl is the implementation-level interface to a
|
|
|
|
// generic bound synchronous instrument
|
|
|
|
type BoundSyncImpl interface {
|
|
|
|
|
|
|
|
// RecordOne captures a single synchronous metric event.
|
2020-11-11 17:24:12 +02:00
|
|
|
RecordOne(ctx context.Context, number number.Number)
|
2020-05-14 22:10:48 +02:00
|
|
|
|
|
|
|
// Unbind frees the resources associated with this bound instrument. It
|
|
|
|
// does not affect the metric this bound instrument was created through.
|
|
|
|
Unbind()
|
|
|
|
}
|
|
|
|
|
|
|
|
// AsyncImpl is an implementation-level interface to an
|
|
|
|
// asynchronous instrument (e.g., Observer instruments).
|
|
|
|
type AsyncImpl interface {
|
|
|
|
InstrumentImpl
|
|
|
|
}
|
|
|
|
|
|
|
|
// WrapMeterImpl constructs a `Meter` implementation from a
|
|
|
|
// `MeterImpl` implementation.
|
2020-09-16 18:09:45 +02:00
|
|
|
func WrapMeterImpl(impl MeterImpl, instrumentationName string, opts ...MeterOption) Meter {
|
2020-05-14 22:10:48 +02:00
|
|
|
return Meter{
|
2020-06-12 18:11:17 +02:00
|
|
|
impl: impl,
|
2020-09-16 18:09:45 +02:00
|
|
|
name: instrumentationName,
|
2021-05-27 16:53:56 +02:00
|
|
|
version: NewMeterConfig(opts...).InstrumentationVersion(),
|
2020-05-14 22:10:48 +02:00
|
|
|
}
|
|
|
|
}
|