Skip to main content

Prometheus metrics collector for FastAPI event loop lag and thread pool utilization

Project description

fastapi-runtime-details-collector

Prometheus metrics collector for FastAPI applications that exposes event loop health and thread pool utilization in real time.

Why

FastAPI runs on an asyncio event loop with a thread pool for synchronous route handlers. Neither is observable out of the box. This library adds two key signals:

  • Event loop lag — how long the loop was blocked before it could process the next iteration. Sustained lag means CPU-bound or blocking work is starving your async handlers.
  • Thread pool saturation — how many of anyio's sync-handler threads are currently active versus the total capacity.

Installation

pip install fastapi-runtime-details-collector

Requires Python 3.10+ and a FastAPI application already using prometheus_client to expose a /metrics endpoint.

Metrics

Metric Type Description
fastapi_eventloop_lag_seconds Gauge Drift between a scheduled asyncio.sleep and its actual wake-up, in seconds
fastapi_eventloop_tasks_total Gauge Number of asyncio tasks currently pending in the event loop
fastapi_threadpool_capacity_tokens Gauge Total token capacity of anyio's default thread limiter (max concurrent sync handlers)
fastapi_threadpool_active_threads Gauge Number of sync handler threads currently executing (anyio borrowed tokens)
fastapi_metrics_last_collection_timestamp_seconds Gauge Unix timestamp of the last successful metrics collection

Metrics are collected every second by a background task. No metrics are exposed until the first successful collection.

Setup

1. Expose a /metrics endpoint

If you don't already have one:

pip install prometheus-client
from prometheus_client import make_asgi_app

metrics_app = make_asgi_app()
app.mount("/metrics", metrics_app)

2. Register the collector in your lifespan

from contextlib import asynccontextmanager
from fastapi import FastAPI
from fastapi_runtime_details_collector import FastAPIRuntimeCollector, setup_lag_monitor

@asynccontextmanager
async def lifespan(app: FastAPI):
    collector = FastAPIRuntimeCollector()
    task = setup_lag_monitor(collector)
    yield
    task.cancel()

app = FastAPI(lifespan=lifespan)

setup_lag_monitor must be called from within a running anyio event loop, so the FastAPI lifespan startup is the right place.

Custom registry

If you use a custom Prometheus registry instead of the global default:

from prometheus_client import CollectorRegistry
from prometheus_client import make_asgi_app
from fastapi_runtime_details_collector import FastAPIRuntimeCollector, setup_lag_monitor

registry = CollectorRegistry()

@asynccontextmanager
async def lifespan(app: FastAPI):
    collector = FastAPIRuntimeCollector(registry=registry)
    task = setup_lag_monitor(collector)
    yield
    task.cancel()

metrics_app = make_asgi_app(registry=registry)
app.mount("/metrics", metrics_app)

Full example

from contextlib import asynccontextmanager
from fastapi import FastAPI
from prometheus_client import make_asgi_app
from fastapi_runtime_details_collector import FastAPIRuntimeCollector, setup_lag_monitor


@asynccontextmanager
async def lifespan(app: FastAPI):
    collector = FastAPIRuntimeCollector()
    task = setup_lag_monitor(collector)
    yield
    task.cancel()


app = FastAPI(lifespan=lifespan)
app.mount("/metrics", make_asgi_app())


@app.get("/")
async def root():
    return {"status": "ok"}

Run with uvicorn main:app and scrape http://localhost:8000/metrics.

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

fastapi_runtime_details_collector-1.0.0.tar.gz (4.4 kB view details)

Uploaded Source

Built Distribution

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

File details

Details for the file fastapi_runtime_details_collector-1.0.0.tar.gz.

File metadata

File hashes

Hashes for fastapi_runtime_details_collector-1.0.0.tar.gz
Algorithm Hash digest
SHA256 c543affd1855973ac4772e46de052eddbd300b40f9e07e3bf62a275b9fad4079
MD5 b87b8719c788fecd54f33907ae336b36
BLAKE2b-256 3353a7b2a058c46f858a5a6ce7b93488faf20ab97d0d2f822f5224a60df2d00a

See more details on using hashes here.

Provenance

The following attestation bundles were made for fastapi_runtime_details_collector-1.0.0.tar.gz:

Publisher: publish-pypi.yml on SIB-rennes/fastapi_runtime_details_collector

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

File details

Details for the file fastapi_runtime_details_collector-1.0.0-py3-none-any.whl.

File metadata

File hashes

Hashes for fastapi_runtime_details_collector-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 27a788afa76d6237aff829af49b5476166c9629cf0f86e9e8de15410b08bc28a
MD5 3505e18646f9d348638e700212697b23
BLAKE2b-256 c01bbc85ec09a5b46ca67aa9f2105ce37c158831f0478ab768df477f6df57811

See more details on using hashes here.

Provenance

The following attestation bundles were made for fastapi_runtime_details_collector-1.0.0-py3-none-any.whl:

Publisher: publish-pypi.yml on SIB-rennes/fastapi_runtime_details_collector

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