Skip to main content

Module for exporting monitoring values for Prometheus

Project description

Faust Prometheus Exporter

Module for exporting monitoring values for Prometheus

PyPI PyPI - Python Version GitLab last commit

Test coverage Downloads GitLab stars

Functionality

  • Adds /metrics endpoint
  • Gives basic Prometheus-client metrics
  • Gives custom user`s metrics
  • Adds internal faust metrics

Installation

pip install faust-prometheus-exporter

Quick start

import logging
from random import randint

import faust
from prometheus_client import Counter, Histogram

from faust_prometheus import FaustPrometheusExporter

logger = logging.getLogger('app')

# Prometheus custom metrics
prometheus_counter_topic_1_messages = Counter('topic_1_messages', 'Count of messages successfully processed from topic_1')
prometheus_histogram_size_messages = Histogram('size_messages', 'Histogram about messages size')

app = faust.App(
    'faust_prometheus',
    broker='localhost:9092',
)

# Adding the Prometheus Exporter
exporter = FaustPrometheusExporter(app)

topic_1 = app.topic('topic_1')

@app.agent(topic_1)
async def agent_topic_1(messages: faust.Stream[str]):
    async for message in messages:
        logger.info(f'Received topic_1 message: {message}')
        prometheus_counter_topic_1_messages.inc()
        prometheus_histogram_size_messages.observe(len(message))

@app.timer(interval=1.0)
async def example_sender(app):
    await topic_1.send(value='Nisi lorem ullamco veniam elit' * randint(1, 10))

if __name__ == '__main__':
    app.main()

Contribute

Issue Tracker: https://gitlab.com/rocshers/python/faust-prometheus/-/issues
Source Code: https://gitlab.com/rocshers/python/faust-prometheus

Before adding changes:

make install-dev

After changes:

make format test

Download files

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

Source Distribution

faust_prometheus_exporter-0.1.0a1.tar.gz (4.1 kB view details)

Uploaded Source

Built Distribution

File details

Details for the file faust_prometheus_exporter-0.1.0a1.tar.gz.

File metadata

  • Download URL: faust_prometheus_exporter-0.1.0a1.tar.gz
  • Upload date:
  • Size: 4.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.6.1 CPython/3.8.18 Linux/5.15.0-83-generic

File hashes

Hashes for faust_prometheus_exporter-0.1.0a1.tar.gz
Algorithm Hash digest
SHA256 ac679e8d5b534f672f42e519408362ed6f0a07146662d875d0522279c44227d0
MD5 a10c73f2b5a88da7287084a54d16276a
BLAKE2b-256 3dd5440fb8205c4232c499f8eeb30152b578a792c64e61543d28b9ff1f22cf9e

See more details on using hashes here.

File details

Details for the file faust_prometheus_exporter-0.1.0a1-py3-none-any.whl.

File metadata

File hashes

Hashes for faust_prometheus_exporter-0.1.0a1-py3-none-any.whl
Algorithm Hash digest
SHA256 55566bc924dbcd8a9b73be1e433f65553fc7bf22c3b7605d540f81de7f3bc094
MD5 24e0f0e67044e55e8993248c0f520960
BLAKE2b-256 f4ded03a48b04b3498e10c37447236acb9c42b84db3fe9eeb309ea90cfa3715c

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