mirror of
https://github.com/open-telemetry/opentelemetry-go.git
synced 2025-01-18 03:22:12 +02:00
65ebe5e50f
* PoC of embedded private method ifaces * Rename embed to embedded * Add an embedded iface for all instruments * Fix metric/instrument tests * Fix global and otel * Fix SDK * Comment the embedded pkg types * Update the embedded pkg docs * Update otel/metric docs about impls * Update otel/metric type docs on impl * Update docs in otel/metric/instrument on default * Add changes to changelog * Apply suggestions from code review Co-authored-by: Robert Pająk <pellared@hotmail.com> * Apply feedback on URLs * Reword based on feedback * Make it clear we only recommended embedding noop * Ignore links with godot linter --------- Co-authored-by: Robert Pająk <pellared@hotmail.com>
99 lines
3.9 KiB
Go
99 lines
3.9 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 provides the OpenTelemetry API used to measure metrics about
|
|
source code operation.
|
|
|
|
This API is separate from its implementation so the instrumentation built from
|
|
it is reusable. See [go.opentelemetry.io/otel/sdk/metric] for the official
|
|
OpenTelemetry implementation of this API.
|
|
|
|
All measurements made with this package are made via instruments. These
|
|
instruments are created by a [Meter] which itself is created by a
|
|
[MeterProvider]. Applications need to accept a [MeterProvider] implementation
|
|
as a starting point when instrumenting. This can be done directly, or by using
|
|
the OpenTelemetry global MeterProvider via [GetMeterProvider]. Using an
|
|
appropriately named [Meter] from the accepted [MeterProvider], instrumentation
|
|
can then be built from the [Meter]'s instruments. See
|
|
[go.opentelemetry.io/otel/metric/instrument] for documentation on each
|
|
instrument and its intended use.
|
|
|
|
# API Implementations
|
|
|
|
This package does not conform to the standard Go versioning policy, all of its
|
|
interfaces may have methods added to them without a package major version bump.
|
|
This non-standard API evolution could surprise an uninformed implementation
|
|
author. They could unknowingly build their implementation in a way that would
|
|
result in a runtime panic for their users that update to the new API.
|
|
|
|
The API is designed to help inform an instrumentation author about this
|
|
non-standard API evolution. It requires them to choose a default behavior for
|
|
unimplemented interface methods. There are three behavior choices they can
|
|
make:
|
|
|
|
- Compilation failure
|
|
- Panic
|
|
- Default to another implementation
|
|
|
|
All interfaces in this API embed a corresponding interface from
|
|
[go.opentelemetry.io/otel/metric/embedded]. If an author wants the default
|
|
behavior of their implementations to be a compilation failure, signaling to
|
|
their users they need to update to the latest version of that implementation,
|
|
they need to embed the corresponding interface from
|
|
[go.opentelemetry.io/otel/metric/embedded] in their implementation. For
|
|
example,
|
|
|
|
import "go.opentelemetry.io/otel/metric/embedded"
|
|
|
|
type MeterProvider struct {
|
|
embedded.MeterProvider
|
|
// ...
|
|
}
|
|
|
|
If an author wants the default behavior of their implementations to a panic,
|
|
they need to embed the API interface directly.
|
|
|
|
import "go.opentelemetry.io/otel/metric"
|
|
|
|
type MeterProvider struct {
|
|
metric.MeterProvider
|
|
// ...
|
|
}
|
|
|
|
This is not a recommended behavior as it could lead to publishing packages that
|
|
contain runtime panics when users update other package that use newer versions
|
|
of [go.opentelemetry.io/otel/metric].
|
|
|
|
Finally, an author can embed another implementation in theirs. The embedded
|
|
implementation will be used for methods not defined by the author. For example,
|
|
an author who want to default to silently dropping the call can use
|
|
[go.opentelemetry.io/otel/metric/noop]:
|
|
|
|
import "go.opentelemetry.io/otel/metric/noop"
|
|
|
|
type MeterProvider struct {
|
|
noop.MeterProvider
|
|
// ...
|
|
}
|
|
|
|
It is strongly recommended that authors only embed
|
|
[go.opentelemetry.io/otel/metric/noop] if they choose this default behavior.
|
|
That implementation is the only one OpenTelemetry authors can guarantee will
|
|
fully implement all the API interfaces when a user updates their API.
|
|
|
|
[GetMeterProvider]: https://pkg.go.dev/go.opentelemetry.io/otel#GetMeterProvider
|
|
*/
|
|
package metric // import "go.opentelemetry.io/otel/metric"
|