LLM Tracker
Build your own real-time LLM usage tracker

This is a template for an LLM performance tracker dashboard and LLM cost calculator. It is built with Next.js, Tinybird and Clerk
Use this template to bootstrap a multi-tenant, user-facing LLM analytics dashboard and cost calculator.
Features:
- Track LLM costs, requests, tokens and duration by model, provider, organization, project, environment and user
- Multi-tenant user-facing dashboard
- AI cost calculator
- Vector search
- Ask AI integration
Fork it and make it your own! You can track your own metrics and dimensions.
Tech stack:
- Next.js - Application
- Tinybird - Analytics
- OpenAI - AI features
- Vercel AI SDK - AI features
- Vercel - Application deployment
- Clerk - User management and auth
- Tremor - Charts
Live Demo
Quick Start
Get started by forking the GitHub repository and then customizing it to your needs.
Start Tinybird locally:
curl https://tinybird.co | sh
cd tinybird
tb local start
tb login
tb dev
token ls # copy the read_pipes token
Configure the Next.js application:
cd dashboard/ai-analytics
cp .env.example .env
Edit the .env file with your Tinybird API key and other configuration.
NEXT_PUBLIC_TINYBIRD_API_URL=http://localhost:7181
# read_pipes token
NEXT_PUBLIC_TINYBIRD_API_KEY=
Start the Next.js application:
cd dashboard/ai-analytics
npm install
npm run dev
Open the application in your browser:
http://localhost:3000
Instrumentation
Instrument your LLM calls and send events to Tinybird. Some examples:
Deployment
- Fork and connect this repository to Vercel.
- Set the environment variables in Vercel.
- Configure your
TINYBIRD_HOST
andTINYBIRD_TOKEN
in the CI/CD GitHub actions to deploy to Tinybird.
Multi-tenancy
Create a Clerk project and set up these environment variables in your Next.js application:
# workspace ID for multi-tenant JWT tokens
TINYBIRD_WORKSPACE_ID=
# workspace admin token for multi-tenant JWT tokens
TINYBIRD_JWT_SECRET=
# Clerk publishable key
NEXT_PUBLIC_CLERK_PUBLISHABLE_KEY=
# Clerk secret key
CLERK_SECRET_KEY=
# Clerk sign in URL
NEXT_PUBLIC_CLERK_SIGN_IN_URL=/sign-in
NEXT_PUBLIC_CLERK_SIGN_UP_URL=/sign-up
NEXT_PUBLIC_CLERK_AFTER_SIGN_IN_URL=/
NEXT_PUBLIC_CLERK_AFTER_SIGN_UP_URL=/
The middleware will get the org:name
permission from the Clerk user and use it to create a Tinybird JWT token with the organization
dimension fixed to that value. Read more about Tinybird JWT tokens here.
Watch a video of the Clerk + Tinybird JWT token flow
Mock Data
For local testing, generate mock data with the following commands:
cd tinybird/mocknpm installnpm run generate -- --start-date 2025-02-01 --end-date 2025-03-31 --events-per-day 100 --output ../fixtures/llm_events.ndjson
The generate-llm-events.js script generates the embeddings.