Skip to main content

Exemplar monitoring client — singleton SDK with heartbeat helpers

Project description

exemplar-python-sdk

Python client for Exemplar monitoring. The client is a singleton: initialize once with your API key, then send heartbeats from sync or async code.

Install

From PyPI (import name is still exemplar):

pip install exemplar-sdk

From a local checkout, poetry install installs this project into Poetry’s virtualenv (no separate pip step needed):

poetry install

To smoke-test the built wheel inside that same env (after poetry build):

poetry run pip install dist/exemplar_sdk-*.whl

Using plain pip install dist/... uses whatever pip is first on your PATH (often system Python) and can fail with permission errors on macOS.

Requires Python 3.9+.

Usage

1. Initialize once (API key)

Call init at application startup (before any heartbeat). A second init raises RuntimeError.

import exemplar

exemplar.init(api_key="<personal_access_token>")
# optional: exemplar.init(api_key="...", base_url="https://production-api.exemplar.dev")

2a. Simple heartbeat (sync)

Use from a cron job, Celery task, Flask/Django view, or any synchronous code:

import exemplar

exemplar.init(api_key=os.environ["EXEMPLAR_API_KEY"])

exemplar.send_heartbeat(
    "69c3a0754e257b7d18094f9a",
    metadata={"hostname": "worker-01"},
)

This sends POST /api/monitoring/heartbeat with Content-Type: application/json and header X-API-Key: <token>, matching:

curl -sS -X POST 'https://production-api.exemplar.dev/api/monitoring/heartbeat' \
  -H 'Content-Type: application/json' \
  -H 'X-API-Key: <personal_access_token>' \
  -d '{"monitor_id":"69c3a0754e257b7d18094f9a","metadata":{"hostname":"worker-01"}}'

2b. Background loop (async)

For FastAPI, Starlette, asyncio services, or any framework that runs an async event loop: start a task that heartbeats on an interval (like a cron in the background):

import asyncio
import exemplar

async def main():
    exemplar.init(api_key="...")
    asyncio.create_task(
        exemplar.heartbeat_background_loop(
            "69c3a0754e257b7d18094f9a",
            interval_seconds=60.0,
            metadata={"hostname": "worker-01"},
        )
    )
    ...

Cancel the task when shutting down. Pass a shared httpx.AsyncClient if you want connection reuse with other HTTP calls.

Development

poetry install
poetry run pytest

API summary

Function Role
exemplar.init(api_key=..., base_url=...) Create singleton (call once)
exemplar.get_client() Access the client after init
exemplar.send_heartbeat(monitor_id, metadata=...) One synchronous POST
exemplar.heartbeat_background_loop(...) Async infinite loop with interval_seconds

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

exemplar_python_sdk-0.1.0.tar.gz (4.7 kB view details)

Uploaded Source

Built Distribution

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

exemplar_python_sdk-0.1.0-py3-none-any.whl (5.8 kB view details)

Uploaded Python 3

File details

Details for the file exemplar_python_sdk-0.1.0.tar.gz.

File metadata

  • Download URL: exemplar_python_sdk-0.1.0.tar.gz
  • Upload date:
  • Size: 4.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.2 CPython/3.12.4 Darwin/24.5.0

File hashes

Hashes for exemplar_python_sdk-0.1.0.tar.gz
Algorithm Hash digest
SHA256 b656ec7cf93ad91c3a0dcb85ac163543aa7147c69408a7e6d2e0ce104f1455d1
MD5 9369f2d0b135e798d54222c7a6217371
BLAKE2b-256 c811dac6b9ee13b8f951f92bb0d9be638fed0f537d5bff7ee7912b3a363bb8d8

See more details on using hashes here.

File details

Details for the file exemplar_python_sdk-0.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for exemplar_python_sdk-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 cecce21ca8a1daa26e6e1a0e791f5ed91bd2b3ff96122683ed19304f58eaf82d
MD5 04a86a53efd05ff14b016634a9141acd
BLAKE2b-256 1d3635dff55e7e4df41031cd2728bdb8e9708615d304f1ab90b7c8314841640b

See more details on using hashes here.

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