PostHog Exporter
PostHog is an analytics platform with AI observability features for monitoring LLM applications. The PostHog exporter sends your traces to PostHog as structured events, providing insights into token usage, costs, latency, and conversation flows.
InstallationDirect link to Installation
npm install @mastra/posthog@beta
ConfigurationDirect link to Configuration
PrerequisitesDirect link to Prerequisites
- PostHog Account: Sign up at posthog.com
- Project API Key: Get your project API key from PostHog Settings → Project API Key
- Environment Variables: Set your credentials
POSTHOG_API_KEY=phc_xxxxxxxxxxxxxxxx
POSTHOG_HOST=https://us.i.posthog.com # Optional: EU region or self-hosted URL
Basic SetupDirect link to Basic Setup
import { Mastra } from "@mastra/core";
import { Observability } from "@mastra/observability";
import { PosthogExporter } from "@mastra/posthog";
export const mastra = new Mastra({
observability: new Observability({
configs: {
posthog: {
serviceName: "my-service",
exporters: [
new PosthogExporter({
apiKey: process.env.POSTHOG_API_KEY,
}),
],
},
},
}),
});
Configuration OptionsDirect link to Configuration Options
Complete ConfigurationDirect link to Complete Configuration
new PosthogExporter({
// Required credentials
apiKey: process.env.POSTHOG_API_KEY!,
// Optional settings
host: "https://us.i.posthog.com", // Default: US region
// or "https://eu.i.posthog.com" for EU region
// or your self-hosted URL
// Batching configuration
flushAt: 20, // Batch size (default: 20)
flushInterval: 10000, // Flush interval in ms (default: 10000)
serverless: false, // Serverless mode: flushAt=10, flushInterval=2000
// User identification
defaultDistinctId: "anonymous", // Fallback if no userId in metadata
// Privacy settings
enablePrivacyMode: false, // Excludes input/output from generation events
// Diagnostic logging
logLevel: "info", // debug | info | warn | error
});
Serverless ModeDirect link to Serverless Mode
Optimized batching for serverless environments:
new PosthogExporter({
apiKey: process.env.POSTHOG_API_KEY!,
serverless: true, // Configures smaller batches for faster flushing
});
Privacy ModeDirect link to Privacy Mode
Exclude input/output data from generation events while preserving token metrics:
new PosthogExporter({
apiKey: process.env.POSTHOG_API_KEY!,
enablePrivacyMode: true, // Removes $ai_input and $ai_output_choices
});
Using TagsDirect link to Using Tags
Tags help you categorize and filter traces in PostHog's AI analytics. Add tags when executing agents or workflows:
const result = await agent.generate({
messages: [{ role: "user", content: "Hello" }],
tracingOptions: {
tags: ["production", "experiment-v2", "user-request"],
},
});
Tags are added as event properties where the tag name is the key and the value is set to true. In PostHog's trace view, filter by a tag using the is set filter (e.g., "production is set" shows all traces with the production tag). Common use cases include:
- Environment labels:
"production","staging" - Experiment tracking:
"experiment-v1","control-group" - Priority levels:
"priority-high","batch-job" - User segments:
"beta-user","enterprise"