Skip to main content

A Python package to send data using Prometheus remote write protocol.

Project description

Prometheus Remote Writer

Python package License

Introduction

prometheus-remote-writer is a Python library designed to simplify the process of writing data to a database using the Prometheus Remote Write protocol. This library is platform-independent and aims to provide developers with an intuitive way to send time-series data to Prometheus-compatible storage.

Key Features

  • Easily write data to Prometheus-compatible storage backends.
  • Supports custom HTTP headers and authentication methods.
  • Provides a simple and easy-to-use API.
  • Supports batch data sending to improve transmission efficiency.

Installation

Before using prometheus-remote-writer, ensure that Python 3.8 or higher is installed on your system.

pip install prometheus-remote-writer

Quick Start

Here's a simple example of how to use prometheus-remote-writer in your project:

from prometheus_remote_writer import RemoteWriter

# Create a RemoteWriter instance
writer = RemoteWriter(
    url='https://your-prometheus-server/api/v1/write',
    headers={'Authorization': 'Bearer YOUR_ACCESS_TOKEN'}
)

# Prepare the data to send
data = [
    {
        'metric': {'__name__': 'cpu_usage', 'host': 'server1'},
        'values': [23.5, 24.1, 22.8],
        'timestamps': [1609459200000, 1609459260000, 1609459320000]
    }
]

# Send the data
writer.send(data)

Configuration

RemoteWriter supports the following configuration parameters: url (required): The URL of the Prometheus remote write endpoint. headers (optional): Custom HTTP headers for authentication or other purposes. timeout (optional): Request timeout in seconds, default is 10 seconds.

Unit Testing

This project uses pytest for unit testing. To run the tests, execute the following command:

pytest

Contribution Guide

We welcome contributions from the community! To contribute to prometheus-remote-writer, please follow these steps: Fork the repository. Create your feature branch (git checkout -b feature/YourFeature). Commit your changes (git commit -m 'Add some feature'). Push to the branch (git push origin feature/YourFeature). Open a pull request.

FAQ

Why can't I connect to the Prometheus server?

Ensure your network connection is active and the url is correct. You may also need to configure firewall rules to allow traffic.

How do I report a bug?

Please file a bug report on the GitHub issues page with detailed information and steps to reproduce the issue.

License

This project is licensed under the Apache License 2.0. See the LICENSE file for details.

Contact

If you have any questions or suggestions, feel free to contact us at xy.kong@gmail.com.

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_remote_writer-0.1.2.tar.gz (15.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

prometheus_remote_writer-0.1.2-py3-none-any.whl (17.0 kB view details)

Uploaded Python 3

File details

Details for the file prometheus_remote_writer-0.1.2.tar.gz.

File metadata

  • Download URL: prometheus_remote_writer-0.1.2.tar.gz
  • Upload date:
  • Size: 15.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for prometheus_remote_writer-0.1.2.tar.gz
Algorithm Hash digest
SHA256 e1bae269fd5a5d56566dd659155ad184ba5fced15883dc30210b0926474b45ce
MD5 33b427eba5c62b7db9f2c94c4378415e
BLAKE2b-256 99fd051dc7877b0c0abd880458326a593694116cbc2087d0584dde80807cea7f

See more details on using hashes here.

Provenance

The following attestation bundles were made for prometheus_remote_writer-0.1.2.tar.gz:

Publisher: python-publish.yml on xykong/prometheus-remote-writer

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file prometheus_remote_writer-0.1.2-py3-none-any.whl.

File metadata

File hashes

Hashes for prometheus_remote_writer-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 76dd1f28bff9db6001be6c70cba22e1479261fc795e64fa2aa0cb55328cb89c3
MD5 573913a6cc1582bb1337f243c288b874
BLAKE2b-256 c8fd0e55e80fa65f3bf5e0e5ce437614826a46c648c303e57a59cd9eb0fc59a0

See more details on using hashes here.

Provenance

The following attestation bundles were made for prometheus_remote_writer-0.1.2-py3-none-any.whl:

Publisher: python-publish.yml on xykong/prometheus-remote-writer

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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