2020-05-14 13:10:48 -07: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.
|
|
|
|
|
|
|
|
package metric
|
|
|
|
|
2020-05-19 21:33:10 -07:00
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
|
2020-08-17 20:25:03 -07:00
|
|
|
"go.opentelemetry.io/otel/label"
|
2020-05-19 21:33:10 -07:00
|
|
|
)
|
2020-05-14 13:10:48 -07:00
|
|
|
|
|
|
|
// The file is organized as follows:
|
|
|
|
//
|
|
|
|
// - Observation type
|
|
|
|
// - Three kinds of Observer callback (int64, float64, batch)
|
|
|
|
// - Three kinds of Observer result (int64, float64, batch)
|
|
|
|
// - Three kinds of Observe() function (int64, float64, batch)
|
|
|
|
// - Three kinds of AsyncRunner interface (abstract, single, batch)
|
|
|
|
// - Two kinds of Observer constructor (int64, float64)
|
|
|
|
// - Two kinds of Observation() function (int64, float64)
|
|
|
|
// - Various internals
|
|
|
|
|
|
|
|
// Observation is used for reporting an asynchronous batch of metric
|
|
|
|
// values. Instances of this type should be created by asynchronous
|
2020-05-18 11:03:43 -07:00
|
|
|
// instruments (e.g., Int64ValueObserver.Observation()).
|
2020-05-14 13:10:48 -07:00
|
|
|
type Observation struct {
|
|
|
|
// number needs to be aligned for 64-bit atomic operations.
|
|
|
|
number Number
|
|
|
|
instrument AsyncImpl
|
|
|
|
}
|
|
|
|
|
2020-08-15 11:56:19 +08:00
|
|
|
// Int64ObserverFunc is a type of callback that integral
|
2020-05-14 13:10:48 -07:00
|
|
|
// observers run.
|
2020-08-15 11:56:19 +08:00
|
|
|
type Int64ObserverFunc func(context.Context, Int64ObserverResult)
|
2020-05-14 13:10:48 -07:00
|
|
|
|
2020-08-15 11:56:19 +08:00
|
|
|
// Float64ObserverFunc is a type of callback that floating point
|
2020-05-14 13:10:48 -07:00
|
|
|
// observers run.
|
2020-08-15 11:56:19 +08:00
|
|
|
type Float64ObserverFunc func(context.Context, Float64ObserverResult)
|
2020-05-14 13:10:48 -07:00
|
|
|
|
2020-08-15 11:56:19 +08:00
|
|
|
// BatchObserverFunc is a callback argument for use with any
|
2020-05-14 13:10:48 -07:00
|
|
|
// Observer instrument that will be reported as a batch of
|
|
|
|
// observations.
|
2020-08-15 11:56:19 +08:00
|
|
|
type BatchObserverFunc func(context.Context, BatchObserverResult)
|
2020-05-14 13:10:48 -07:00
|
|
|
|
|
|
|
// Int64ObserverResult is passed to an observer callback to capture
|
|
|
|
// observations for one asynchronous integer metric instrument.
|
|
|
|
type Int64ObserverResult struct {
|
|
|
|
instrument AsyncImpl
|
2020-08-17 20:25:03 -07:00
|
|
|
function func([]label.KeyValue, ...Observation)
|
2020-05-14 13:10:48 -07:00
|
|
|
}
|
|
|
|
|
2020-08-17 00:45:21 +08:00
|
|
|
// Float64ObserverResult is passed to an observer callback to capture
|
2020-05-14 13:10:48 -07:00
|
|
|
// observations for one asynchronous floating point metric instrument.
|
|
|
|
type Float64ObserverResult struct {
|
|
|
|
instrument AsyncImpl
|
2020-08-17 20:25:03 -07:00
|
|
|
function func([]label.KeyValue, ...Observation)
|
2020-05-14 13:10:48 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
// BatchObserverResult is passed to a batch observer callback to
|
|
|
|
// capture observations for multiple asynchronous instruments.
|
|
|
|
type BatchObserverResult struct {
|
2020-08-17 20:25:03 -07:00
|
|
|
function func([]label.KeyValue, ...Observation)
|
2020-05-14 13:10:48 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
// Observe captures a single integer value from the associated
|
|
|
|
// instrument callback, with the given labels.
|
2020-08-17 20:25:03 -07:00
|
|
|
func (ir Int64ObserverResult) Observe(value int64, labels ...label.KeyValue) {
|
2020-05-14 13:10:48 -07:00
|
|
|
ir.function(labels, Observation{
|
|
|
|
instrument: ir.instrument,
|
|
|
|
number: NewInt64Number(value),
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
// Observe captures a single floating point value from the associated
|
|
|
|
// instrument callback, with the given labels.
|
2020-08-17 20:25:03 -07:00
|
|
|
func (fr Float64ObserverResult) Observe(value float64, labels ...label.KeyValue) {
|
2020-05-14 13:10:48 -07:00
|
|
|
fr.function(labels, Observation{
|
|
|
|
instrument: fr.instrument,
|
|
|
|
number: NewFloat64Number(value),
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
// Observe captures a multiple observations from the associated batch
|
|
|
|
// instrument callback, with the given labels.
|
2020-08-17 20:25:03 -07:00
|
|
|
func (br BatchObserverResult) Observe(labels []label.KeyValue, obs ...Observation) {
|
2020-05-14 13:10:48 -07:00
|
|
|
br.function(labels, obs...)
|
|
|
|
}
|
|
|
|
|
|
|
|
// AsyncRunner is expected to convert into an AsyncSingleRunner or an
|
|
|
|
// AsyncBatchRunner. SDKs will encounter an error if the AsyncRunner
|
|
|
|
// does not satisfy one of these interfaces.
|
|
|
|
type AsyncRunner interface {
|
|
|
|
// AnyRunner() is a non-exported method with no functional use
|
|
|
|
// other than to make this a non-empty interface.
|
|
|
|
AnyRunner()
|
|
|
|
}
|
|
|
|
|
|
|
|
// AsyncSingleRunner is an interface implemented by single-observer
|
|
|
|
// callbacks.
|
|
|
|
type AsyncSingleRunner interface {
|
|
|
|
// Run accepts a single instrument and function for capturing
|
|
|
|
// observations of that instrument. Each call to the function
|
|
|
|
// receives one captured observation. (The function accepts
|
|
|
|
// multiple observations so the same implementation can be
|
|
|
|
// used for batch runners.)
|
2020-08-17 20:25:03 -07:00
|
|
|
Run(ctx context.Context, single AsyncImpl, capture func([]label.KeyValue, ...Observation))
|
2020-05-14 13:10:48 -07:00
|
|
|
|
|
|
|
AsyncRunner
|
|
|
|
}
|
|
|
|
|
|
|
|
// AsyncBatchRunner is an interface implemented by batch-observer
|
|
|
|
// callbacks.
|
|
|
|
type AsyncBatchRunner interface {
|
|
|
|
// Run accepts a function for capturing observations of
|
|
|
|
// multiple instruments.
|
2020-08-17 20:25:03 -07:00
|
|
|
Run(ctx context.Context, capture func([]label.KeyValue, ...Observation))
|
2020-05-14 13:10:48 -07:00
|
|
|
|
|
|
|
AsyncRunner
|
|
|
|
}
|
|
|
|
|
2020-08-15 11:56:19 +08:00
|
|
|
var _ AsyncSingleRunner = (*Int64ObserverFunc)(nil)
|
|
|
|
var _ AsyncSingleRunner = (*Float64ObserverFunc)(nil)
|
|
|
|
var _ AsyncBatchRunner = (*BatchObserverFunc)(nil)
|
2020-05-14 13:10:48 -07:00
|
|
|
|
|
|
|
// newInt64AsyncRunner returns a single-observer callback for integer Observer instruments.
|
2020-08-15 11:56:19 +08:00
|
|
|
func newInt64AsyncRunner(c Int64ObserverFunc) AsyncSingleRunner {
|
2020-05-14 13:10:48 -07:00
|
|
|
return &c
|
|
|
|
}
|
|
|
|
|
|
|
|
// newFloat64AsyncRunner returns a single-observer callback for floating point Observer instruments.
|
2020-08-15 11:56:19 +08:00
|
|
|
func newFloat64AsyncRunner(c Float64ObserverFunc) AsyncSingleRunner {
|
2020-05-14 13:10:48 -07:00
|
|
|
return &c
|
|
|
|
}
|
|
|
|
|
|
|
|
// newBatchAsyncRunner returns a batch-observer callback use with multiple Observer instruments.
|
2020-08-15 11:56:19 +08:00
|
|
|
func newBatchAsyncRunner(c BatchObserverFunc) AsyncBatchRunner {
|
2020-05-14 13:10:48 -07:00
|
|
|
return &c
|
|
|
|
}
|
|
|
|
|
|
|
|
// AnyRunner implements AsyncRunner.
|
2020-08-15 11:56:19 +08:00
|
|
|
func (*Int64ObserverFunc) AnyRunner() {}
|
2020-05-14 13:10:48 -07:00
|
|
|
|
|
|
|
// AnyRunner implements AsyncRunner.
|
2020-08-15 11:56:19 +08:00
|
|
|
func (*Float64ObserverFunc) AnyRunner() {}
|
2020-05-14 13:10:48 -07:00
|
|
|
|
|
|
|
// AnyRunner implements AsyncRunner.
|
2020-08-15 11:56:19 +08:00
|
|
|
func (*BatchObserverFunc) AnyRunner() {}
|
2020-05-14 13:10:48 -07:00
|
|
|
|
|
|
|
// Run implements AsyncSingleRunner.
|
2020-08-17 20:25:03 -07:00
|
|
|
func (i *Int64ObserverFunc) Run(ctx context.Context, impl AsyncImpl, function func([]label.KeyValue, ...Observation)) {
|
2020-05-19 21:33:10 -07:00
|
|
|
(*i)(ctx, Int64ObserverResult{
|
2020-05-14 13:10:48 -07:00
|
|
|
instrument: impl,
|
|
|
|
function: function,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
// Run implements AsyncSingleRunner.
|
2020-08-17 20:25:03 -07:00
|
|
|
func (f *Float64ObserverFunc) Run(ctx context.Context, impl AsyncImpl, function func([]label.KeyValue, ...Observation)) {
|
2020-05-19 21:33:10 -07:00
|
|
|
(*f)(ctx, Float64ObserverResult{
|
2020-05-14 13:10:48 -07:00
|
|
|
instrument: impl,
|
|
|
|
function: function,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
// Run implements AsyncBatchRunner.
|
2020-08-17 20:25:03 -07:00
|
|
|
func (b *BatchObserverFunc) Run(ctx context.Context, function func([]label.KeyValue, ...Observation)) {
|
2020-05-19 21:33:10 -07:00
|
|
|
(*b)(ctx, BatchObserverResult{
|
2020-05-14 13:10:48 -07:00
|
|
|
function: function,
|
|
|
|
})
|
|
|
|
}
|
2020-05-18 11:03:43 -07:00
|
|
|
|
2020-05-19 11:49:24 -07:00
|
|
|
// wrapInt64ValueObserverInstrument converts an AsyncImpl into Int64ValueObserver.
|
2020-05-18 11:03:43 -07:00
|
|
|
func wrapInt64ValueObserverInstrument(asyncInst AsyncImpl, err error) (Int64ValueObserver, error) {
|
|
|
|
common, err := checkNewAsync(asyncInst, err)
|
|
|
|
return Int64ValueObserver{asyncInstrument: common}, err
|
|
|
|
}
|
|
|
|
|
2020-05-19 11:49:24 -07:00
|
|
|
// wrapFloat64ValueObserverInstrument converts an AsyncImpl into Float64ValueObserver.
|
2020-05-18 11:03:43 -07:00
|
|
|
func wrapFloat64ValueObserverInstrument(asyncInst AsyncImpl, err error) (Float64ValueObserver, error) {
|
|
|
|
common, err := checkNewAsync(asyncInst, err)
|
|
|
|
return Float64ValueObserver{asyncInstrument: common}, err
|
|
|
|
}
|
2020-05-19 11:49:24 -07:00
|
|
|
|
|
|
|
// wrapInt64SumObserverInstrument converts an AsyncImpl into Int64SumObserver.
|
|
|
|
func wrapInt64SumObserverInstrument(asyncInst AsyncImpl, err error) (Int64SumObserver, error) {
|
|
|
|
common, err := checkNewAsync(asyncInst, err)
|
|
|
|
return Int64SumObserver{asyncInstrument: common}, err
|
|
|
|
}
|
|
|
|
|
|
|
|
// wrapFloat64SumObserverInstrument converts an AsyncImpl into Float64SumObserver.
|
|
|
|
func wrapFloat64SumObserverInstrument(asyncInst AsyncImpl, err error) (Float64SumObserver, error) {
|
|
|
|
common, err := checkNewAsync(asyncInst, err)
|
|
|
|
return Float64SumObserver{asyncInstrument: common}, err
|
|
|
|
}
|
2020-05-20 10:19:51 -07:00
|
|
|
|
|
|
|
// wrapInt64UpDownSumObserverInstrument converts an AsyncImpl into Int64UpDownSumObserver.
|
|
|
|
func wrapInt64UpDownSumObserverInstrument(asyncInst AsyncImpl, err error) (Int64UpDownSumObserver, error) {
|
|
|
|
common, err := checkNewAsync(asyncInst, err)
|
|
|
|
return Int64UpDownSumObserver{asyncInstrument: common}, err
|
|
|
|
}
|
|
|
|
|
|
|
|
// wrapFloat64UpDownSumObserverInstrument converts an AsyncImpl into Float64UpDownSumObserver.
|
|
|
|
func wrapFloat64UpDownSumObserverInstrument(asyncInst AsyncImpl, err error) (Float64UpDownSumObserver, error) {
|
|
|
|
common, err := checkNewAsync(asyncInst, err)
|
|
|
|
return Float64UpDownSumObserver{asyncInstrument: common}, err
|
|
|
|
}
|