-
Notifications
You must be signed in to change notification settings - Fork 624
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Setup Prometheus Remote Write Exporter (#180)
- Loading branch information
Showing
17 changed files
with
2,354 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
5 changes: 5 additions & 0 deletions
5
exporter/opentelemetry-exporter-prometheus-remote-write/CHANGELOG.md
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
# Changelog | ||
|
||
## Unreleased | ||
- Setup for Prometheus Remote Write Exporter | ||
((#180)[https://github.com/open-telemetry/opentelemetry-python-contrib/pull/180]) |
27 changes: 27 additions & 0 deletions
27
exporter/opentelemetry-exporter-prometheus-remote-write/README.rst
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,27 @@ | ||
OpenTelemetry Prometheus Remote Write Exporter | ||
============================================== | ||
|
||
This library allows exporting metric data to `Prometheus Remote Write Integrated Backends | ||
<https://prometheus.io/docs/operating/integrations/>`_. Latest `types.proto | ||
<https://github.com/prometheus/prometheus/blob/master/prompb/types.proto>` and `remote.proto | ||
<https://github.com/prometheus/prometheus/blob/master/prompb/remote.proto>` Protocol Buffers | ||
used to create WriteRequest objects were taken from Prometheus repository. Development is | ||
currently in progress. | ||
|
||
Installation | ||
------------ | ||
|
||
:: | ||
|
||
pip install opentelemetry-exporter-prometheus-remote-write | ||
|
||
|
||
.. _Prometheus: https://prometheus.io/ | ||
.. _OpenTelemetry: https://github.com/open-telemetry/opentelemetry-python/ | ||
|
||
|
||
References | ||
---------- | ||
|
||
* `Prometheus <https://prometheus.io/>`_ | ||
* `OpenTelemetry Project <https://opentelemetry.io/>`_ |
49 changes: 49 additions & 0 deletions
49
exporter/opentelemetry-exporter-prometheus-remote-write/setup.cfg
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,49 @@ | ||
# 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. | ||
# | ||
[metadata] | ||
name = opentelemetry-exporter-prometheus-remote-write | ||
description = Prometheus Remote Write Metrics Exporter for OpenTelemetry | ||
long_description = file: README.rst | ||
long_description_content_type = text/x-rst | ||
author = OpenTelemetry Authors | ||
author_email = cncf-opentelemetry-contributors@lists.cncf.io | ||
url = https://github.com/open-telemetry/opentelemetry-python-contrib/tree/master/exporter/opentelemetry-exporter-prometheus-remote-write | ||
platforms = any | ||
license = Apache-2.0 | ||
classifiers = | ||
Development Status :: 4 - Beta | ||
Intended Audience :: Developers | ||
License :: OSI Approved :: Apache Software License | ||
Programming Language :: Python | ||
Programming Language :: Python :: 3 | ||
Programming Language :: Python :: 3.5 | ||
Programming Language :: Python :: 3.6 | ||
Programming Language :: Python :: 3.7 | ||
Programming Language :: Python :: 3.8 | ||
|
||
[options] | ||
python_requires = >=3.5 | ||
package_dir= | ||
=src | ||
packages=find_namespace: | ||
install_requires = | ||
opentelemetry-api == 0.16.dev0 | ||
opentelemetry-sdk == 0.16.dev0 | ||
|
||
[options.packages.find] | ||
where = src | ||
|
||
[options.extras_require] | ||
test = |
32 changes: 32 additions & 0 deletions
32
exporter/opentelemetry-exporter-prometheus-remote-write/setup.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,32 @@ | ||
# 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. | ||
|
||
import os | ||
|
||
import setuptools | ||
|
||
BASE_DIR = os.path.dirname(__file__) | ||
VERSION_FILENAME = os.path.join( | ||
BASE_DIR, | ||
"src", | ||
"opentelemetry", | ||
"exporter", | ||
"prometheus_remote_write", | ||
"version.py", | ||
) | ||
PACKAGE_INFO = {} | ||
with open(VERSION_FILENAME) as f: | ||
exec(f.read(), PACKAGE_INFO) | ||
|
||
setuptools.setup(version=PACKAGE_INFO["__version__"]) |
113 changes: 113 additions & 0 deletions
113
...er-prometheus-remote-write/src/opentelemetry/exporter/prometheus_remote_write/__init__.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,113 @@ | ||
# 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 typing import Dict, Sequence | ||
|
||
from opentelemetry.exporter.prometheus_remote_write.gen.types_pb2 import ( | ||
Label, | ||
Sample, | ||
TimeSeries, | ||
) | ||
from opentelemetry.sdk.metrics.export import ( | ||
ExportRecord, | ||
MetricsExporter, | ||
MetricsExportResult, | ||
) | ||
|
||
|
||
class PrometheusRemoteWriteMetricsExporter(MetricsExporter): | ||
""" | ||
Prometheus remote write metric exporter for OpenTelemetry. | ||
Args: | ||
endpoint: url where data will be sent (Required) | ||
basic_auth: username and password for authentication (Optional) | ||
bearer_token: token used for authentication (Optional) | ||
bearer_token_file: filepath to file containing authentication token (Optional) | ||
headers: additional headers for remote write request (Optional | ||
""" | ||
|
||
def __init__( | ||
self, | ||
endpoint: str, | ||
basic_auth: Dict = None, | ||
bearer_token: str = None, | ||
bearer_token_file: str = None, | ||
headers: Dict = None, | ||
): | ||
raise NotImplementedError() | ||
|
||
def export( | ||
self, export_records: Sequence[ExportRecord] | ||
) -> MetricsExportResult: | ||
raise NotImplementedError() | ||
|
||
def shutdown(self) -> None: | ||
raise NotImplementedError() | ||
|
||
def convert_to_timeseries( | ||
self, export_records: Sequence[ExportRecord] | ||
) -> Sequence[TimeSeries]: | ||
raise NotImplementedError() | ||
|
||
def convert_from_sum(self, sum_record: ExportRecord) -> TimeSeries: | ||
raise NotImplementedError() | ||
|
||
def convert_from_min_max_sum_count( | ||
self, min_max_sum_count_record: ExportRecord | ||
) -> TimeSeries: | ||
raise NotImplementedError() | ||
|
||
def convert_from_histogram( | ||
self, histogram_record: ExportRecord | ||
) -> TimeSeries: | ||
raise NotImplementedError() | ||
|
||
def convert_from_last_value( | ||
self, last_value_record: ExportRecord | ||
) -> TimeSeries: | ||
raise NotImplementedError() | ||
|
||
def convert_from_value_observer( | ||
self, value_observer_record: ExportRecord | ||
) -> TimeSeries: | ||
raise NotImplementedError() | ||
|
||
def convert_from_quantile( | ||
self, summary_record: ExportRecord | ||
) -> TimeSeries: | ||
raise NotImplementedError() | ||
|
||
# pylint: disable=no-member | ||
def create_timeseries( | ||
self, export_record: ExportRecord, name, value: float | ||
) -> TimeSeries: | ||
raise NotImplementedError() | ||
|
||
def create_sample(self, timestamp: int, value: float) -> Sample: | ||
raise NotImplementedError() | ||
|
||
def create_label(self, name: str, value: str) -> Label: | ||
raise NotImplementedError() | ||
|
||
def build_message(self, timeseries: Sequence[TimeSeries]) -> bytes: | ||
raise NotImplementedError() | ||
|
||
def get_headers(self) -> Dict: | ||
raise NotImplementedError() | ||
|
||
def send_message( | ||
self, message: bytes, headers: Dict | ||
) -> MetricsExportResult: | ||
raise NotImplementedError() |
145 changes: 145 additions & 0 deletions
145
...-remote-write/src/opentelemetry/exporter/prometheus_remote_write/gen/gogoproto/gogo.proto
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,145 @@ | ||
// Protocol Buffers for Go with Gadgets | ||
// | ||
// Copyright (c) 2013, The GoGo Authors. All rights reserved. | ||
// http://github.com/gogo/protobuf | ||
// | ||
// Redistribution and use in source and binary forms, with or without | ||
// modification, are permitted provided that the following conditions are | ||
// met: | ||
// | ||
// * Redistributions of source code must retain the above copyright | ||
// notice, this list of conditions and the following disclaimer. | ||
// * Redistributions in binary form must reproduce the above | ||
// copyright notice, this list of conditions and the following disclaimer | ||
// in the documentation and/or other materials provided with the | ||
// distribution. | ||
// | ||
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | ||
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | ||
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | ||
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | ||
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | ||
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | ||
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | ||
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | ||
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||
|
||
syntax = "proto2"; | ||
package gogoproto; | ||
|
||
import "google/protobuf/descriptor.proto"; | ||
|
||
option java_package = "com.google.protobuf"; | ||
option java_outer_classname = "GoGoProtos"; | ||
option go_package = "github.com/gogo/protobuf/gogoproto"; | ||
|
||
extend google.protobuf.EnumOptions { | ||
optional bool goproto_enum_prefix = 62001; | ||
optional bool goproto_enum_stringer = 62021; | ||
optional bool enum_stringer = 62022; | ||
optional string enum_customname = 62023; | ||
optional bool enumdecl = 62024; | ||
} | ||
|
||
extend google.protobuf.EnumValueOptions { | ||
optional string enumvalue_customname = 66001; | ||
} | ||
|
||
extend google.protobuf.FileOptions { | ||
optional bool goproto_getters_all = 63001; | ||
optional bool goproto_enum_prefix_all = 63002; | ||
optional bool goproto_stringer_all = 63003; | ||
optional bool verbose_equal_all = 63004; | ||
optional bool face_all = 63005; | ||
optional bool gostring_all = 63006; | ||
optional bool populate_all = 63007; | ||
optional bool stringer_all = 63008; | ||
optional bool onlyone_all = 63009; | ||
|
||
optional bool equal_all = 63013; | ||
optional bool description_all = 63014; | ||
optional bool testgen_all = 63015; | ||
optional bool benchgen_all = 63016; | ||
optional bool marshaler_all = 63017; | ||
optional bool unmarshaler_all = 63018; | ||
optional bool stable_marshaler_all = 63019; | ||
|
||
optional bool sizer_all = 63020; | ||
|
||
optional bool goproto_enum_stringer_all = 63021; | ||
optional bool enum_stringer_all = 63022; | ||
|
||
optional bool unsafe_marshaler_all = 63023; | ||
optional bool unsafe_unmarshaler_all = 63024; | ||
|
||
optional bool goproto_extensions_map_all = 63025; | ||
optional bool goproto_unrecognized_all = 63026; | ||
optional bool gogoproto_import = 63027; | ||
optional bool protosizer_all = 63028; | ||
optional bool compare_all = 63029; | ||
optional bool typedecl_all = 63030; | ||
optional bool enumdecl_all = 63031; | ||
|
||
optional bool goproto_registration = 63032; | ||
optional bool messagename_all = 63033; | ||
|
||
optional bool goproto_sizecache_all = 63034; | ||
optional bool goproto_unkeyed_all = 63035; | ||
} | ||
|
||
extend google.protobuf.MessageOptions { | ||
optional bool goproto_getters = 64001; | ||
optional bool goproto_stringer = 64003; | ||
optional bool verbose_equal = 64004; | ||
optional bool face = 64005; | ||
optional bool gostring = 64006; | ||
optional bool populate = 64007; | ||
optional bool stringer = 67008; | ||
optional bool onlyone = 64009; | ||
|
||
optional bool equal = 64013; | ||
optional bool description = 64014; | ||
optional bool testgen = 64015; | ||
optional bool benchgen = 64016; | ||
optional bool marshaler = 64017; | ||
optional bool unmarshaler = 64018; | ||
optional bool stable_marshaler = 64019; | ||
|
||
optional bool sizer = 64020; | ||
|
||
optional bool unsafe_marshaler = 64023; | ||
optional bool unsafe_unmarshaler = 64024; | ||
|
||
optional bool goproto_extensions_map = 64025; | ||
optional bool goproto_unrecognized = 64026; | ||
|
||
optional bool protosizer = 64028; | ||
optional bool compare = 64029; | ||
|
||
optional bool typedecl = 64030; | ||
|
||
optional bool messagename = 64033; | ||
|
||
optional bool goproto_sizecache = 64034; | ||
optional bool goproto_unkeyed = 64035; | ||
} | ||
|
||
extend google.protobuf.FieldOptions { | ||
optional bool nullable = 65001; | ||
optional bool embed = 65002; | ||
optional string customtype = 65003; | ||
optional string customname = 65004; | ||
optional string jsontag = 65005; | ||
optional string moretags = 65006; | ||
optional string casttype = 65007; | ||
optional string castkey = 65008; | ||
optional string castvalue = 65009; | ||
|
||
optional bool stdtime = 65010; | ||
optional bool stdduration = 65011; | ||
optional bool wktpointer = 65012; | ||
|
||
} | ||
|
Oops, something went wrong.