forked from open-telemetry/opentelemetry-python
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy path__init__.py
More file actions
88 lines (70 loc) · 2.63 KB
/
__init__.py
File metadata and controls
88 lines (70 loc) · 2.63 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
# 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.
from enum import Enum
from typing import Sequence, Tuple
from opentelemetry import metrics as metrics_api
from opentelemetry.sdk.metrics.export.aggregate import Aggregator
class MetricsExportResult(Enum):
SUCCESS = 0
FAILURE = 1
class MetricRecord:
def __init__(
self,
instrument: metrics_api.InstrumentT,
labels: Tuple[Tuple[str, str]],
aggregator: Aggregator,
):
self.instrument = instrument
self.labels = labels
self.aggregator = aggregator
class MetricsExporter:
"""Interface for exporting metrics.
Interface to be implemented by services that want to export recorded
metrics in its own format.
"""
def export(
self, metric_records: Sequence[MetricRecord]
) -> "MetricsExportResult":
"""Exports a batch of telemetry data.
Args:
metric_records: A sequence of `MetricRecord` s. A `MetricRecord`
contains the metric to be exported, the labels associated
with that metric, as well as the aggregator used to export the
current checkpointed value.
Returns:
The result of the export
"""
def shutdown(self) -> None:
"""Shuts down the exporter.
Called when the SDK is shut down.
"""
class ConsoleMetricsExporter(MetricsExporter):
"""Implementation of `MetricsExporter` that prints metrics to the console.
This class can be used for diagnostic purposes. It prints the exported
metrics to the console STDOUT.
"""
def export(
self, metric_records: Sequence[MetricRecord]
) -> "MetricsExportResult":
for record in metric_records:
print(
'{}(data="{}", labels="{}", value={}, exemplars={})'.format(
type(self).__name__,
record.instrument,
record.labels,
record.aggregator.checkpoint,
record.aggregator.checkpoint_exemplars,
)
)
return MetricsExportResult.SUCCESS