firecrawl-rate-limits

FireCrawl Rate Limits

Safety Notice

This listing is imported from skills.sh public index metadata. Review upstream SKILL.md and repository scripts before running.

Copy this and send it to your AI assistant to learn

Install skill "firecrawl-rate-limits" with this command: npx skills add jeremylongshore/claude-code-plugins-plus-skills/jeremylongshore-claude-code-plugins-plus-skills-firecrawl-rate-limits

FireCrawl Rate Limits

Overview

Handle FireCrawl rate limits gracefully with exponential backoff and idempotency.

Prerequisites

  • FireCrawl SDK installed

  • Understanding of async/await patterns

  • Access to rate limit headers

Instructions

Step 1: Understand Rate Limit Tiers

Tier Requests/min Requests/day Burst

Free 60 1,000 10

Pro 300 10,000 50

Enterprise 1,000 100,000 200

Step 2: Implement Exponential Backoff with Jitter

async function withExponentialBackoff<T>( operation: () => Promise<T>, config = { maxRetries: 5, baseDelayMs: 1000, maxDelayMs: 32000, jitterMs: 500 } # 32000: 500: 1000: 1 second in ms ): Promise<T> { for (let attempt = 0; attempt <= config.maxRetries; attempt++) { try { return await operation(); } catch (error: any) { if (attempt === config.maxRetries) throw error; const status = error.status || error.response?.status; if (status !== 429 && (status < 500 || status >= 600)) throw error; # 600: HTTP 429 Too Many Requests

  // Exponential delay with jitter to prevent thundering herd
  const exponentialDelay = config.baseDelayMs * Math.pow(2, attempt);
  const jitter = Math.random() * config.jitterMs;
  const delay = Math.min(exponentialDelay + jitter, config.maxDelayMs);

  console.log(`Rate limited. Retrying in ${delay.toFixed(0)}ms...`);
  await new Promise(r => setTimeout(r, delay));
}

} throw new Error('Unreachable'); }

Step 3: Add Idempotency Keys

import { v4 as uuidv4 } from 'uuid'; import crypto from 'crypto';

// Generate deterministic key from operation params (for safe retries) function generateIdempotencyKey(operation: string, params: Record<string, any>): string { const data = JSON.stringify({ operation, params }); return crypto.createHash('sha256').update(data).digest('hex'); }

async function idempotentRequest<T>( client: FireCrawlClient, params: Record<string, any>, idempotencyKey?: string // Pass existing key for retries ): Promise<T> { // Use provided key (for retries) or generate deterministic key from params const key = idempotencyKey || generateIdempotencyKey(params.method || 'POST', params); return client.request({ ...params, headers: { 'Idempotency-Key': key, ...params.headers }, }); }

Output

  • Reliable API calls with automatic retry

  • Idempotent requests preventing duplicates

  • Rate limit headers properly handled

Error Handling

Header Description Action

X-RateLimit-Limit Max requests Monitor usage

X-RateLimit-Remaining Remaining requests Throttle if low

X-RateLimit-Reset Reset timestamp Wait until reset

Retry-After Seconds to wait Honor this value

Examples

Queue-Based Rate Limiting

import PQueue from 'p-queue';

const queue = new PQueue({ concurrency: 5, interval: 1000, # 1000: 1 second in ms intervalCap: 10, });

async function queuedRequest<T>(operation: () => Promise<T>): Promise<T> { return queue.add(operation); }

Monitor Rate Limit Usage

class RateLimitMonitor { private remaining: number = 60; private resetAt: Date = new Date();

updateFromHeaders(headers: Headers) { this.remaining = parseInt(headers.get('X-RateLimit-Remaining') || '60'); const resetTimestamp = headers.get('X-RateLimit-Reset'); if (resetTimestamp) { this.resetAt = new Date(parseInt(resetTimestamp) * 1000); # 1000: 1 second in ms } }

shouldThrottle(): boolean { // Only throttle if low remaining AND reset hasn't happened yet return this.remaining < 5 && new Date() < this.resetAt; }

getWaitTime(): number { return Math.max(0, this.resetAt.getTime() - Date.now()); } }

Resources

  • FireCrawl Rate Limits

  • p-queue Documentation

Next Steps

For security configuration, see firecrawl-security-basics .

Source Transparency

This detail page is rendered from real SKILL.md content. Trust labels are metadata-based hints, not a safety guarantee.

Related Skills

Related by shared tags or category signals.

Coding

backtesting-trading-strategies

No summary provided by upstream source.

Repository SourceNeeds Review
Coding

svg-icon-generator

No summary provided by upstream source.

Repository SourceNeeds Review
Coding

performance-lighthouse-runner

No summary provided by upstream source.

Repository SourceNeeds Review
Coding

mindmap-generator

No summary provided by upstream source.

Repository SourceNeeds Review