mirror of
https://github.com/ceph/ceph-csi.git
synced 2024-11-24 15:20:19 +00:00
182 lines
5.8 KiB
Go
182 lines
5.8 KiB
Go
|
// 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 // import "go.opentelemetry.io/otel/metric"
|
||
|
|
||
|
import (
|
||
|
"context"
|
||
|
|
||
|
"go.opentelemetry.io/otel/attribute"
|
||
|
"go.opentelemetry.io/otel/metric/instrument"
|
||
|
"go.opentelemetry.io/otel/metric/instrument/asyncfloat64"
|
||
|
"go.opentelemetry.io/otel/metric/instrument/asyncint64"
|
||
|
"go.opentelemetry.io/otel/metric/instrument/syncfloat64"
|
||
|
"go.opentelemetry.io/otel/metric/instrument/syncint64"
|
||
|
)
|
||
|
|
||
|
// NewNoopMeterProvider creates a MeterProvider that does not record any metrics.
|
||
|
func NewNoopMeterProvider() MeterProvider {
|
||
|
return noopMeterProvider{}
|
||
|
}
|
||
|
|
||
|
type noopMeterProvider struct{}
|
||
|
|
||
|
func (noopMeterProvider) Meter(string, ...MeterOption) Meter {
|
||
|
return noopMeter{}
|
||
|
}
|
||
|
|
||
|
// NewNoopMeter creates a Meter that does not record any metrics.
|
||
|
func NewNoopMeter() Meter {
|
||
|
return noopMeter{}
|
||
|
}
|
||
|
|
||
|
type noopMeter struct{}
|
||
|
|
||
|
// AsyncInt64 creates an instrument that does not record any metrics.
|
||
|
func (noopMeter) AsyncInt64() asyncint64.InstrumentProvider {
|
||
|
return nonrecordingAsyncInt64Instrument{}
|
||
|
}
|
||
|
|
||
|
// AsyncFloat64 creates an instrument that does not record any metrics.
|
||
|
func (noopMeter) AsyncFloat64() asyncfloat64.InstrumentProvider {
|
||
|
return nonrecordingAsyncFloat64Instrument{}
|
||
|
}
|
||
|
|
||
|
// SyncInt64 creates an instrument that does not record any metrics.
|
||
|
func (noopMeter) SyncInt64() syncint64.InstrumentProvider {
|
||
|
return nonrecordingSyncInt64Instrument{}
|
||
|
}
|
||
|
|
||
|
// SyncFloat64 creates an instrument that does not record any metrics.
|
||
|
func (noopMeter) SyncFloat64() syncfloat64.InstrumentProvider {
|
||
|
return nonrecordingSyncFloat64Instrument{}
|
||
|
}
|
||
|
|
||
|
// RegisterCallback creates a register callback that does not record any metrics.
|
||
|
func (noopMeter) RegisterCallback([]instrument.Asynchronous, func(context.Context)) error {
|
||
|
return nil
|
||
|
}
|
||
|
|
||
|
type nonrecordingAsyncFloat64Instrument struct {
|
||
|
instrument.Asynchronous
|
||
|
}
|
||
|
|
||
|
var (
|
||
|
_ asyncfloat64.InstrumentProvider = nonrecordingAsyncFloat64Instrument{}
|
||
|
_ asyncfloat64.Counter = nonrecordingAsyncFloat64Instrument{}
|
||
|
_ asyncfloat64.UpDownCounter = nonrecordingAsyncFloat64Instrument{}
|
||
|
_ asyncfloat64.Gauge = nonrecordingAsyncFloat64Instrument{}
|
||
|
)
|
||
|
|
||
|
func (n nonrecordingAsyncFloat64Instrument) Counter(string, ...instrument.Option) (asyncfloat64.Counter, error) {
|
||
|
return n, nil
|
||
|
}
|
||
|
|
||
|
func (n nonrecordingAsyncFloat64Instrument) UpDownCounter(string, ...instrument.Option) (asyncfloat64.UpDownCounter, error) {
|
||
|
return n, nil
|
||
|
}
|
||
|
|
||
|
func (n nonrecordingAsyncFloat64Instrument) Gauge(string, ...instrument.Option) (asyncfloat64.Gauge, error) {
|
||
|
return n, nil
|
||
|
}
|
||
|
|
||
|
func (nonrecordingAsyncFloat64Instrument) Observe(context.Context, float64, ...attribute.KeyValue) {
|
||
|
|
||
|
}
|
||
|
|
||
|
type nonrecordingAsyncInt64Instrument struct {
|
||
|
instrument.Asynchronous
|
||
|
}
|
||
|
|
||
|
var (
|
||
|
_ asyncint64.InstrumentProvider = nonrecordingAsyncInt64Instrument{}
|
||
|
_ asyncint64.Counter = nonrecordingAsyncInt64Instrument{}
|
||
|
_ asyncint64.UpDownCounter = nonrecordingAsyncInt64Instrument{}
|
||
|
_ asyncint64.Gauge = nonrecordingAsyncInt64Instrument{}
|
||
|
)
|
||
|
|
||
|
func (n nonrecordingAsyncInt64Instrument) Counter(string, ...instrument.Option) (asyncint64.Counter, error) {
|
||
|
return n, nil
|
||
|
}
|
||
|
|
||
|
func (n nonrecordingAsyncInt64Instrument) UpDownCounter(string, ...instrument.Option) (asyncint64.UpDownCounter, error) {
|
||
|
return n, nil
|
||
|
}
|
||
|
|
||
|
func (n nonrecordingAsyncInt64Instrument) Gauge(string, ...instrument.Option) (asyncint64.Gauge, error) {
|
||
|
return n, nil
|
||
|
}
|
||
|
|
||
|
func (nonrecordingAsyncInt64Instrument) Observe(context.Context, int64, ...attribute.KeyValue) {
|
||
|
}
|
||
|
|
||
|
type nonrecordingSyncFloat64Instrument struct {
|
||
|
instrument.Synchronous
|
||
|
}
|
||
|
|
||
|
var (
|
||
|
_ syncfloat64.InstrumentProvider = nonrecordingSyncFloat64Instrument{}
|
||
|
_ syncfloat64.Counter = nonrecordingSyncFloat64Instrument{}
|
||
|
_ syncfloat64.UpDownCounter = nonrecordingSyncFloat64Instrument{}
|
||
|
_ syncfloat64.Histogram = nonrecordingSyncFloat64Instrument{}
|
||
|
)
|
||
|
|
||
|
func (n nonrecordingSyncFloat64Instrument) Counter(string, ...instrument.Option) (syncfloat64.Counter, error) {
|
||
|
return n, nil
|
||
|
}
|
||
|
|
||
|
func (n nonrecordingSyncFloat64Instrument) UpDownCounter(string, ...instrument.Option) (syncfloat64.UpDownCounter, error) {
|
||
|
return n, nil
|
||
|
}
|
||
|
|
||
|
func (n nonrecordingSyncFloat64Instrument) Histogram(string, ...instrument.Option) (syncfloat64.Histogram, error) {
|
||
|
return n, nil
|
||
|
}
|
||
|
|
||
|
func (nonrecordingSyncFloat64Instrument) Add(context.Context, float64, ...attribute.KeyValue) {
|
||
|
|
||
|
}
|
||
|
|
||
|
func (nonrecordingSyncFloat64Instrument) Record(context.Context, float64, ...attribute.KeyValue) {
|
||
|
|
||
|
}
|
||
|
|
||
|
type nonrecordingSyncInt64Instrument struct {
|
||
|
instrument.Synchronous
|
||
|
}
|
||
|
|
||
|
var (
|
||
|
_ syncint64.InstrumentProvider = nonrecordingSyncInt64Instrument{}
|
||
|
_ syncint64.Counter = nonrecordingSyncInt64Instrument{}
|
||
|
_ syncint64.UpDownCounter = nonrecordingSyncInt64Instrument{}
|
||
|
_ syncint64.Histogram = nonrecordingSyncInt64Instrument{}
|
||
|
)
|
||
|
|
||
|
func (n nonrecordingSyncInt64Instrument) Counter(string, ...instrument.Option) (syncint64.Counter, error) {
|
||
|
return n, nil
|
||
|
}
|
||
|
|
||
|
func (n nonrecordingSyncInt64Instrument) UpDownCounter(string, ...instrument.Option) (syncint64.UpDownCounter, error) {
|
||
|
return n, nil
|
||
|
}
|
||
|
|
||
|
func (n nonrecordingSyncInt64Instrument) Histogram(string, ...instrument.Option) (syncint64.Histogram, error) {
|
||
|
return n, nil
|
||
|
}
|
||
|
|
||
|
func (nonrecordingSyncInt64Instrument) Add(context.Context, int64, ...attribute.KeyValue) {
|
||
|
}
|
||
|
func (nonrecordingSyncInt64Instrument) Record(context.Context, int64, ...attribute.KeyValue) {
|
||
|
}
|