Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add metrics exporter requirements to the metrics SDK spec #1864

Merged
merged 19 commits into from
Aug 25, 2021
Merged
Show file tree
Hide file tree
Changes from 4 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
77 changes: 77 additions & 0 deletions specification/metrics/sdk.md
Original file line number Diff line number Diff line change
Expand Up @@ -296,6 +296,80 @@ example:
* Exporter D is a pull exporter which reacts to another scraper over a named
pipe.

### Interface Definition

`MetricExporter` must support the following functions:

#### Export(batch)
reyang marked this conversation as resolved.
Show resolved Hide resolved

Exports a batch of `Metrics`. Protocol exporters that will implement this
function are typically expected to serialize and transmit the data to the
destination.

`Export` will never be called concurrently for the same exporter instance.
`Export` can be called again only after the current call returns.
jmacd marked this conversation as resolved.
Show resolved Hide resolved

`Export` MUST NOT block indefinitely, there MUST be a reasonable upper limit
after which the call must time out with an error result (Failure).

Any retry logic that is required by the exporter is the responsibility of the
exporter. The default SDK SHOULD NOT implement retry logic, as the required
logic is likely to depend heavily on the specific protocol and backend the spans
reyang marked this conversation as resolved.
Show resolved Hide resolved
are being sent to.
jmacd marked this conversation as resolved.
Show resolved Hide resolved

Individual language clients can decide how to associate
[Resource](../resource/sdk.md) with `Metrics`. Refer to the [tracing SDK
specfication](../trace/sdk.md#additional-span-interfaces) for more information.
reyang marked this conversation as resolved.
Show resolved Hide resolved

**Parameters:**

`batch` - a batch of `Metrics`. The exact data type of the batch is language
jmacd marked this conversation as resolved.
Show resolved Hide resolved
specific, typically it is some kind of list.

Returns: `ExportResult`

`ExportResult` is one of:

* `Success` - The batch has been successfully exported. For protocol exporters
this typically means that the data is sent over the wire and delivered to the
destination server.
* `Failure` - exporting failed. The batch must be dropped. For example, this can
happen when the batch contains bad data and cannot be serialized.

Note: this result may be returned via an async mechanism or a callback, if that
is idiomatic for the language implementation.

#### ForceFlush()

This is a hint to ensure that the export of any `Metrics` the exporter has
received prior to the call to `ForceFlush` SHOULD be completed as soon as
possible, preferably before returning from this method.
reyang marked this conversation as resolved.
Show resolved Hide resolved

`ForceFlush` SHOULD provide a way to let the caller know whether it succeeded,
failed or timed out.

`ForceFlush` SHOULD only be called in cases where it is absolutely necessary,
such as when using some FaaS providers that may suspend the process after an
invocation, but before the exporter exports the completed spans.
reyang marked this conversation as resolved.
Show resolved Hide resolved

`ForceFlush` SHOULD complete or abort within some timeout. `ForceFlush` can be
implemented as a blocking API or an asynchronous API which notifies the caller
via a callback or an event. OpenTelemetry client authors can decide if they want
to make the flush timeout configurable.

#### Shutdown()

Shuts down the exporter. Called when SDK is shut down. This is an opportunity
for exporter to do any cleanup required.

Shutdown should be called only once for each `MetricExporter` instance. After
the call to `Shutdown` subsequent calls to `MetricExporter` are not allowed and
reyang marked this conversation as resolved.
Show resolved Hide resolved
should return a Failure result.

`Shutdown` should not block indefinitely (e.g. if it attempts to flush the data
and the destination is unavailable). OpenTelemetry client authors can decide if
reyang marked this conversation as resolved.
Show resolved Hide resolved
they want to make the shutdown timeout configurable.

### Push Metric Exporter

Push Metric Exporter sends the data on its own schedule. Here are some examples:
Expand All @@ -308,3 +382,6 @@ Push Metric Exporter sends the data on its own schedule. Here are some examples:
Pull Metric Exporter reacts to the metrics scrapers and reports the data
passively. This pattern has been widely adopted by
[Prometheus](https://prometheus.io/).

Pull Metric Exporter SHOULD always return immediately with an indication of
jmacd marked this conversation as resolved.
Show resolved Hide resolved
failure when `ForceFlush` is called.
6 changes: 6 additions & 0 deletions specification/metrics/sdk_exporters/in-memory.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,3 +5,9 @@
Note: this specification is subject to major changes. To avoid thrusting
language client maintainers, we don't recommend OpenTelemetry clients to start
the implementation unless explicitly communicated.

The in-memory exporter accumulates telemetry data in the local memory and allows
reyang marked this conversation as resolved.
Show resolved Hide resolved
to inspect it (useful for e.g. unit tests).

The in-memory exporter MUST support both [pull](../sdk.md#pull-metric-exporter)
reyang marked this conversation as resolved.
Show resolved Hide resolved
mode and [push](../sdk.md#push-metric-exporter) mode.