Skip to main content

Accurate LLM usage & cost tracking for Python backends (FastAPI-native)

Project description

llm-meter 📊

PyPI Version Python Version License

Accurate LLM usage & cost tracking for Python backends.

llm-meter solves the "black box" of LLM costs by providing framework-native (FastAPI) instrumentation that attributes every token, cent, and millisecond to your business-level concepts (User ID, Feature, Endpoint).


⚡ 15-Minute Setup

# Using uv (recommended)
uv add llm-meter

# or pip
pip install llm-meter

1. Initialize & Instrument

from fastapi import FastAPI
from llm_meter import LLMMeter, FastAPIMiddleware
from openai import OpenAI

# 1. Initialize SDK
meter = LLMMeter(
    storage_url="sqlite+aiosqlite:///llm_usage.db",
    providers={"openai": {"api_key": "YOUR_KEY"}}
)

app = FastAPI()

# 2. Add Middleton for automatic attribution
app.add_middleware(FastAPIMiddleware, meter=meter)

# 3. Wrap your client
client = meter.wrap_client(OpenAI())

@app.post("/generate")
async def generate(prompt: str):
    # This call is automatically tracked and attributed to "/generate"
    response = client.chat.completions.create(
        model="gpt-4",
        messages=[{"role": "user", "content": prompt}]
    )
    return {"text": response.choices[0].message.content}

2. Inspect via CLI

# Get a high-level summary
llm-meter usage summary

# See which endpoint costs the most
llm-meter usage by-endpoint

🎯 Key Features

  • Accounting, not Observability: Focuses on cost attribution and usage tracking, not heavy traces or prompt logging.
  • FastAPI Native: Middleware handles request_id and context propagation automatically.
  • Async-Safe: Powered by contextvars to ensure usage is correctly attributed even in complex async workflows.
  • Proxy-Free: Works via SDK-level instrumentation (no network interception or latency overhead).
  • Self-Hosted: You own your data. Supports SQLite (default) and PostgreSQL.

⚠️ v1 Limitations

  • Supports OpenAI and Azure OpenAI.
  • Batch token tracking (Streaming support coming in v1.1).
  • No web UI (everything is available via CLI or SQL).

🛠 Contributing

We love contributions! Please see CONTRIBUTING.md for details on how to get started.


📄 License

This project is licensed under the MIT License - see the LICENSE file for details.

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

llm_meter-0.3.2.tar.gz (111.4 kB view details)

Uploaded Source

Built Distribution

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

llm_meter-0.3.2-py3-none-any.whl (21.8 kB view details)

Uploaded Python 3

File details

Details for the file llm_meter-0.3.2.tar.gz.

File metadata

  • Download URL: llm_meter-0.3.2.tar.gz
  • Upload date:
  • Size: 111.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.9.21 {"installer":{"name":"uv","version":"0.9.21","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for llm_meter-0.3.2.tar.gz
Algorithm Hash digest
SHA256 14c4158ac9c5e2e4c736b092c0e910b1c5c33006339a127f094309df191edf96
MD5 d129d8b641a7c6da7a3f4266637a064d
BLAKE2b-256 ee4aa8d7ce77e674b3227a5e2ba70a3f2de24cc09ac707288355df62142fa7ec

See more details on using hashes here.

File details

Details for the file llm_meter-0.3.2-py3-none-any.whl.

File metadata

  • Download URL: llm_meter-0.3.2-py3-none-any.whl
  • Upload date:
  • Size: 21.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.9.21 {"installer":{"name":"uv","version":"0.9.21","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for llm_meter-0.3.2-py3-none-any.whl
Algorithm Hash digest
SHA256 e23386b4014e15d67b18f83795f582e789103e279fc6f70aee2c96bb6278300f
MD5 36c7bb32063e651df4ed314e761ac3ad
BLAKE2b-256 173f3b32e033e2f25f5b0d76e5e2686d98b28523618ddaaae2b871f6a36bebfb

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