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

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.0rc2.tar.gz.

File metadata

File hashes

Hashes for fastapi_runtime_details_collector-1.0.0rc2.tar.gz
Algorithm Hash digest
SHA256 f32c34d4994c51cdeab8ef78634dacc5148ee54543b9e3bbe592636adaaf74e2
MD5 74ef52ad31267770db4524810e86e056
BLAKE2b-256 211a187b29f6eb53776fdf4cc5b842f6422b862ebc375a6490f2ea64bd57256f

See more details on using hashes here.

Provenance

The following attestation bundles were made for fastapi_runtime_details_collector-1.0.0rc2.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.0rc2-py3-none-any.whl.

File metadata

File hashes

Hashes for fastapi_runtime_details_collector-1.0.0rc2-py3-none-any.whl
Algorithm Hash digest
SHA256 7a3e41561fe1544b04d9739a66c0c25b5d1bc489d6c919130a75fbb2b47f6c49
MD5 22a273608798a08f5ca4c069390eb923
BLAKE2b-256 13e9f721d202cb8fb5a7f208ffad3b15a0e025670509ee4e416eef159698c5aa

See more details on using hashes here.

Provenance

The following attestation bundles were made for fastapi_runtime_details_collector-1.0.0rc2-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