Skip to main content

Versatile metrics collection for Python

Project description

https://readthedocs.org/projects/pymetrics/badge/ https://pepy.tech/badge/pymetrics https://img.shields.io/pypi/l/pymetrics.svg https://api.travis-ci.org/eventbrite/pymetrics.svg https://img.shields.io/pypi/v/pymetrics.svg https://img.shields.io/pypi/wheel/pymetrics.svg https://img.shields.io/pypi/pyversions/pymetrics.svg

PyMetrics is versatile metrics collection library for Python that encapsulates the collection of counters, gauges, histograms, and timers into a generic interface with pluggable publishers so that you can helpfully instrument your applications without suffering vendor lock.


Publishing metrics is a straightforward process involving two steps. First, configure your metrics and publisher(s):

METRICS_CONFIG = {
    'version': 2,
    'error_logger_name': 'pymetrics',
    'publishers': [
        {
            'path': 'pymetrics.publishers.datadog.DogStatsdPublisher',
            'kwargs': {
                'host': 'localhost',
                'port': 8135,
            },
        },
    ],
}

Then, use a pymetrics.recorders.base.MetricsRecorder in your application to collect and publish:

from pymetrics.recorders.default import DefaultMetricsRecorder

metrics = DefaultMetricsRecorder(config=settings.METRICS_CONFIG)

metrics.counter('counter.name').increment()

metrics.gauge('gauge.name', tag_name1='tag_value1', tag_name2='tag_value2').set(12)

metrics.histogram('histogram.name').set(1730)

with metrics.timer('timer.name'):
    do_something()

cumulative_timer = metrics.timer('cumulative_timer.name')
for item in items:
    do_something_without_timing()
    with cumulative_timer:
        do_something_with_timing()

metrics.publish_all()

Provided publisher plugins include Statsd, Datadog, Python Logging, SQLite, and a null publisher. Writing your own is simple and we encourage you to share your work with the community by submitting a pull request.

License

PyMetrics is licensed under the Apache License, version 2.0.

Installation

PyMetrics is available in PyPi and can be installing directly via Pip or listed in setup.py, requirements.txt, or Pipfile:

pip install 'pymetrics~=1.0'
install_requires=[
    ...
    'pymetrics~=1.0',
    ...
]
pymetrics~=1.0
pymetrics = {version="~=1.0"}

Documentation

The complete PyMetrics documentation is available on Read the Docs!

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

pymetrics-1.0.7.tar.gz (24.0 kB view details)

Uploaded Source

Built Distribution

pymetrics-1.0.7-py27.py35.py36.py37.py38-none-any.whl (30.3 kB view details)

Uploaded Python 2.7 Python 3.5 Python 3.6 Python 3.7 Python 3.8

File details

Details for the file pymetrics-1.0.7.tar.gz.

File metadata

  • Download URL: pymetrics-1.0.7.tar.gz
  • Upload date:
  • Size: 24.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.7.1

File hashes

Hashes for pymetrics-1.0.7.tar.gz
Algorithm Hash digest
SHA256 d46f89a264a6f7c9295e980f9f57feb80480206c05f3409bb631b458bbe6bded
MD5 a00424f6a8d9f6a466b8133f63baf831
BLAKE2b-256 4abc732e9990a91f61155efc55b60a4d4bc3e9b7b007e4d0706118f4afdf4352

See more details on using hashes here.

File details

Details for the file pymetrics-1.0.7-py27.py35.py36.py37.py38-none-any.whl.

File metadata

File hashes

Hashes for pymetrics-1.0.7-py27.py35.py36.py37.py38-none-any.whl
Algorithm Hash digest
SHA256 0fad849d675c20491214b61abe913699b5a94e1a689963d700a0ec623493420e
MD5 c31ecdaa25702d5356734e8b7f4ecb77
BLAKE2b-256 1189e904d21494c20d7a2d5fac214ae36fb81913b6fe9b011626dfb1bea96055

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