Skip to main content

Chaos Toolkit extension querying/sending metrics to Prometheus

Project description

Prometheus extension for the Chaos Toolkit

Version License Build Python versions

Prometheus support for the Chaos Toolkit.

Install

To be used from your experiment, this package must be installed in the Python environment where chaostoolkit already lives.

$ pip install chaostoolkit-prometheus

Usage

To use this package, you must create have access to a Prometheus instance via HTTP and be allowed to connect to it.

By default, the Prometheus instance at http://localhost:9090 will be queried. To override, you need to set up the instance details using the prometheus_base_url configuration property:

"configuration": {
  "prometheus_base_url": "http://my.prometheus.server/"
}

This package only exports probes to query for some aspects of your system as monitored by Prometheus.

Here is an example of querying Prometheus at a given moment

{
    "type": "probe",
    "name": "fetch-cpu-just-2mn-ago",
    "provider": {
        "type": "python",
        "module": "chaosprometheus.probes",
        "func": "query",
        "arguments": {
            "query": "process_cpu_seconds_total{job='websvc'}",
            "when": "2 minutes ago"
        }
    }
}

You can also ask for an interval as follows:

{
    "type": "probe",
    "name": "fetch-cpu-over-interval",
    "provider": {
        "type": "python",
        "module": "chaosprometheus.probes",
        "func": "query_interval",
        "arguments": {
            "query": "process_cpu_seconds_total{job='websvc'}",
            "start": "2 minutes ago",
            "end": "now",
            "step": 5
        }
    }
}

In both cases, the probe returns the JSON payload as-is from Prometheus or raises an exception when an error is met.

The result is not further process and should be found in the generated report of the experiment run.

You can also send metrics to a pushgateway service via a control:

{
    "controls": [
        {
            "name": "prometheus",
            "provider": {
                "type": "python",
                "module": "chaosprometheus.metrics",
                "arguments": {
                    "pushgateway_url": "http://someip:9091",
                    "job": "chaostoolkit"
                }
            }
        }
    ]
}

You can also set three more arguments:

  • grouping_key: A mapping of strings to uniquely aggregate multiple runs in the Prometheus backend
  • trace_id: This must be a string which will identify this run uniquely in your metrics. If none is a provided, a random string is generated.
  • experiment_ref: Sometimes it's useful to identify a particular experiment, not just its run, throughout many runs. This is the string to do that. If none is provided, a hash of the experiment is performed and used. The hash is not stable across changes of the experiment of course.

These are particularly useful when you couple this extension with others like Loki where you want to cross-reference between logs and metrics.

Contribute

If you wish to contribute more functions to this package, you are more than welcome to do so. Please, fork this project, make your changes following the usual PEP 8 code style, sprinkling with tests and submit a PR for review.

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

chaostoolkit-prometheus-0.6.0.tar.gz (13.2 kB view details)

Uploaded Source

Built Distribution

chaostoolkit_prometheus-0.6.0-py2.py3-none-any.whl (11.2 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file chaostoolkit-prometheus-0.6.0.tar.gz.

File metadata

File hashes

Hashes for chaostoolkit-prometheus-0.6.0.tar.gz
Algorithm Hash digest
SHA256 4fa346453c325f3d0d8981f93473f8b2348db994a099f85b6f983794971506b2
MD5 619a383825d43a6292cfe2f6bacacf81
BLAKE2b-256 0728c899fd2913b288562e0c7a5f4636c15778f77cb0b5b2c4c6b78592121eb9

See more details on using hashes here.

File details

Details for the file chaostoolkit_prometheus-0.6.0-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for chaostoolkit_prometheus-0.6.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 897d2eb72af359ae93fbff559a44b2f79ffac2ba3eb0ebe72dbc235146019d1c
MD5 80d1a8bb8fd3c997bb921978babbcc9f
BLAKE2b-256 76fc998fa521bf25d412fab79e5d913c60945daa00a2068584ec3662b260c9e7

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