Skip to main content

Asyncio library for creating Prometheus exporters.

Project description

Latest Version Build Status Coverage Status

prometheus-aioexporter is an aysncio-powered library to simplify writing Prometheus exporters.

Exporters are usually implemented as small daemons that expose metrics in text format through a web endpoint (usually /metrics).

Usage

The library provides a PrometheusExporterScript class that serves as an entry point to create services that export Prometheus metrics via an HTTP endpoint.

Creating a new exporter is just a matter of subclassing PrometheusExporterScript and implementing a few methods as needed.

An example usage is the following:

from prometheus_aioexporter.script import PrometheusExporterScript


class MyExporter(PrometheusExporterScript):
    """My Prometheus exporter."""

    def configure_argument_parser(self, parser):
        # Additional arguments to the script
        parser.add_argument('an-option', help='an option')
        # ...

    def configure(self, args):
        # Save attributes that are needed for later
        self.data = do_stuff()
        # ...

    def on_application_startup(self, application):
        # Start other asyncio tasks at application startup
        use(self.data)
        # ...

    def on_application_shutdown(self, application):
        # Stop other asyncio tasks at application shutdown
        use(self.data)
        # ...


script = MyExporter()

Exporter command-line

PrometheusExporterScript provides a few command-line arguments by default:

optional arguments:
  -h, --help            show this help message and exit
  -H HOST, --host HOST  host address to bind (default: localhost)
  -p PORT, --port PORT  port to run the webserver on (default: 9090)
  -L {CRITICAL,ERROR,WARNING,INFO,DEBUG}, --log-level {CRITICAL,ERROR,WARNING,INFO,DEBUG}
                        minimum level for log messages (default: WARNING)
  --process-stats       include process stats in metrics (default: False)

Further options can be added by implementing configure_argument_parser(), which receives the argparse.ArgumentParser instance used by the script.

The script variable from the example above can be referenced in setup.py to generate the script, like

setup(
    ...,
    entry_points={'console_scripts': ['script = path.to.script:script']},
    ...)

The name and description of the exporter can be customized by setting the respective attributes in the script class.

Startup configuration

Additional initial setup (e.g. config file parsing) can be performed by the script by implementing the configure(). This is called at startup with the parsed argument (an argparse.Namespace instance).

Metrics configuration

The metrics exported by the script can be set up by calling create_metrics with a list of MetricConfigs. This is typically done in configure():

def configure(self, args):
    # ...
    self.create_metrics(
        [MetricConfig('metric1', 'a metric', 'gauge', {}),
         MetricConfig('metric2', 'another metric', 'counter', {})])

Web application setup

On startup, PrometheusExporterScript creates a web application which is used to expose metrics.

It’s possible to customize and perform additional startup/shutdown tasks by implementing the on_application_startup and on_application_shutdown methods, which are called with the application instance.

This is a PrometheusExporterApplication instance, which provides a hook to update metrics on each request, before the response is returned to the client. This is called with a dict mapping metric names to metrics.

def on_application_startup(self, application):
    # ...
    application.set_metric_update_handler(self._update_handler)

def _update_handler(self, metrics):
    for name, metric in metrics.items():
        metric.set(...)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

prometheus-aioexporter-1.2.0.tar.gz (11.0 kB view details)

Uploaded Source

Built Distribution

prometheus_aioexporter-1.2.0-py3-none-any.whl (13.5 kB view details)

Uploaded Python 3

File details

Details for the file prometheus-aioexporter-1.2.0.tar.gz.

File metadata

File hashes

Hashes for prometheus-aioexporter-1.2.0.tar.gz
Algorithm Hash digest
SHA256 321c33e7b3178599ccfa1202dad1d6ec761fc17356ce9ba76b9af67bce1d1b4d
MD5 6e8d14c1ef8dcfc0fcfd5e40453726cb
BLAKE2b-256 ef0e9799f08863aaab57b271d2f3d54613249fba5ee1092a6ff8afa7b6589685

See more details on using hashes here.

File details

Details for the file prometheus_aioexporter-1.2.0-py3-none-any.whl.

File metadata

File hashes

Hashes for prometheus_aioexporter-1.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 2f52b47bdd5c864ade4d3c0859cacc963a2217bcbcdbe333831dd5f783cde4e3
MD5 433a346a582e820e8625a3093e7f6b8b
BLAKE2b-256 baa2e29b0964f5a6f1b8f58cafaee817af762e39c84b61a5c16e2a5e4b1ab3da

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page