posthog-cost-tuningClaude Skill

Optimize PostHog costs through tier selection, sampling, and usage monitoring.

1.4k Stars
173 Forks
2025/10/10

Install & Download

Linux / macOS:

请登录后查看安装命令

Windows (PowerShell):

请登录后查看安装命令

Download and extract to ~/.claude/skills/

nameposthog-cost-tuning
descriptionOptimize PostHog costs through tier selection, sampling, and usage monitoring. Use when analyzing PostHog billing, reducing API costs, or implementing usage monitoring and budget alerts. Trigger with phrases like "posthog cost", "posthog billing", "reduce posthog costs", "posthog pricing", "posthog expensive", "posthog budget".
allowed-toolsRead, Grep
version1.0.0
licenseMIT
authorJeremy Longshore <jeremy@intentsolutions.io>

PostHog Cost Tuning

Overview

Optimize PostHog costs through smart tier selection, sampling, and usage monitoring.

Prerequisites

  • Access to PostHog billing dashboard
  • Understanding of current usage patterns
  • Database for usage tracking (optional)
  • Alerting system configured (optional)

Pricing Tiers

TierMonthly CostIncludedOverage
Free$01,000 requestsN/A
Pro$99100,000 requests$0.001/request
EnterpriseCustomUnlimitedVolume discounts

Cost Estimation

interface UsageEstimate {
  requestsPerMonth: number;
  tier: string;
  estimatedCost: number;
  recommendation?: string;
}

function estimatePostHogCost(requestsPerMonth: number): UsageEstimate {
  if (requestsPerMonth <= 1000) {
    return { requestsPerMonth, tier: 'Free', estimatedCost: 0 };
  }

  if (requestsPerMonth <= 100000) {
    return { requestsPerMonth, tier: 'Pro', estimatedCost: 99 };
  }

  const proOverage = (requestsPerMonth - 100000) * 0.001;
  const proCost = 99 + proOverage;

  return {
    requestsPerMonth,
    tier: 'Pro (with overage)',
    estimatedCost: proCost,
    recommendation: proCost > 500
      ? 'Consider Enterprise tier for volume discounts'
      : undefined,
  };
}

Usage Monitoring

class PostHogUsageMonitor {
  private requestCount = 0;
  private bytesTransferred = 0;
  private alertThreshold: number;

  constructor(monthlyBudget: number) {
    this.alertThreshold = monthlyBudget * 0.8; // 80% warning
  }

  track(request: { bytes: number }) {
    this.requestCount++;
    this.bytesTransferred += request.bytes;

    if (this.estimatedCost() > this.alertThreshold) {
      this.sendAlert('Approaching PostHog budget limit');
    }
  }

  estimatedCost(): number {
    return estimatePostHogCost(this.requestCount).estimatedCost;
  }

  private sendAlert(message: string) {
    // Send to Slack, email, PagerDuty, etc.
  }
}

Cost Reduction Strategies

Step 1: Request Sampling

function shouldSample(samplingRate = 0.1): boolean {
  return Math.random() < samplingRate;
}

// Use for non-critical telemetry
if (shouldSample(0.1)) { // 10% sample
  await posthogClient.trackEvent(event);
}

Step 2: Batching Requests

// Instead of N individual calls
await Promise.all(ids.map(id => posthogClient.get(id)));

// Use batch endpoint (1 call)
await posthogClient.batchGet(ids);

Step 3: Caching (from P16)

  • Cache frequently accessed data
  • Use cache invalidation webhooks
  • Set appropriate TTLs

Step 4: Compression

const client = new PostHogClient({
  compression: true, // Enable gzip
});

Budget Alerts

# Set up billing alerts in PostHog dashboard
# Or use API if available:
# Check PostHog documentation for billing APIs

Cost Dashboard Query

-- If tracking usage in your database
SELECT
  DATE_TRUNC('day', created_at) as date,
  COUNT(*) as requests,
  SUM(response_bytes) as bytes,
  COUNT(*) * 0.001 as estimated_cost
FROM posthog_api_logs
WHERE created_at >= NOW() - INTERVAL '30 days'
GROUP BY 1
ORDER BY 1;

Instructions

Step 1: Analyze Current Usage

Review PostHog dashboard for usage patterns and costs.

Step 2: Select Optimal Tier

Use the cost estimation function to find the right tier.

Step 3: Implement Monitoring

Add usage tracking to catch budget overruns early.

Step 4: Apply Optimizations

Enable batching, caching, and sampling where appropriate.

Output

  • Optimized tier selection
  • Usage monitoring implemented
  • Budget alerts configured
  • Cost reduction strategies applied

Error Handling

IssueCauseSolution
Unexpected chargesUntracked usageImplement monitoring
Overage feesWrong tierUpgrade tier
Budget exceededNo alertsSet up alerts
Inefficient usageNo batchingEnable batch requests

Examples

Quick Cost Check

// Estimate monthly cost for your usage
const estimate = estimatePostHogCost(yourMonthlyRequests);
console.log(`Tier: ${estimate.tier}, Cost: $${estimate.estimatedCost}`);
if (estimate.recommendation) {
  console.log(`💡 ${estimate.recommendation}`);
}

Resources

Next Steps

For architecture patterns, see posthog-reference-architecture.

Similar Claude Skills & Agent Workflows