技能 编程开发 Linktree API限速与重试机制

Linktree API限速与重试机制

v20260423
linktree-rate-limits
本技能提供了处理Linktree API限速的全面解决方案。它集成了基于令牌桶算法的限流器和具有指数退避、抖动机制的重试策略。适用于需要进行批量链接更新、定时拉取分析数据或高频数据同步的场景,确保程序调用API时稳定可靠,避免因超出配额而失败。
获取技能
428 次下载
概览

Linktree Rate Limits

Overview

Linktree's API enforces rate limits per OAuth token, with analytics endpoints throttled more aggressively than profile management operations. Agencies managing dozens of creator profiles need to stagger link updates and analytics pulls across accounts to avoid hitting per-token and global IP-based limits. Bulk link reordering and analytics export during campaign launches are the most common rate-limit triggers, especially when synchronizing link performance data with external dashboards on short polling intervals.

Rate Limit Reference

Endpoint Limit Window Scope
Profile read/update 60 req 1 minute Per OAuth token
Link create/update/delete 30 req 1 minute Per OAuth token
Analytics summary 20 req 1 minute Per OAuth token
Analytics detailed (per-link) 10 req 1 minute Per OAuth token
Webhook management 10 req 1 minute Per OAuth token

Rate Limiter Implementation

class LinktreeRateLimiter {
  private tokens: number;
  private lastRefill: number;
  private readonly max: number;
  private readonly refillRate: number;
  private queue: Array<{ resolve: () => void }> = [];

  constructor(maxPerMinute: number) {
    this.max = maxPerMinute;
    this.tokens = maxPerMinute;
    this.lastRefill = Date.now();
    this.refillRate = maxPerMinute / 60_000;
  }

  async acquire(): Promise<void> {
    this.refill();
    if (this.tokens >= 1) { this.tokens -= 1; return; }
    return new Promise(resolve => this.queue.push({ resolve }));
  }

  private refill() {
    const now = Date.now();
    this.tokens = Math.min(this.max, this.tokens + (now - this.lastRefill) * this.refillRate);
    this.lastRefill = now;
    while (this.tokens >= 1 && this.queue.length) {
      this.tokens -= 1;
      this.queue.shift()!.resolve();
    }
  }
}

const linkLimiter = new LinktreeRateLimiter(25);
const analyticsLimiter = new LinktreeRateLimiter(8);

Retry Strategy

async function linktreeRetry<T>(
  limiter: LinktreeRateLimiter, fn: () => Promise<Response>, maxRetries = 3
): Promise<T> {
  for (let attempt = 0; attempt <= maxRetries; attempt++) {
    await limiter.acquire();
    const res = await fn();
    if (res.ok) return res.json();
    if (res.status === 429) {
      const retryAfter = parseInt(res.headers.get("Retry-After") || "30", 10);
      const jitter = Math.random() * 2000;
      await new Promise(r => setTimeout(r, retryAfter * 1000 + jitter));
      continue;
    }
    if (res.status >= 500 && attempt < maxRetries) {
      await new Promise(r => setTimeout(r, Math.pow(2, attempt) * 1500));
      continue;
    }
    throw new Error(`Linktree API ${res.status}: ${await res.text()}`);
  }
  throw new Error("Max retries exceeded");
}

Batch Processing

async function batchUpdateLinks(profileId: string, links: any[], batchSize = 5) {
  const results: any[] = [];
  for (let i = 0; i < links.length; i += batchSize) {
    const batch = links.slice(i, i + batchSize);
    const batchResults = await Promise.all(
      batch.map(link => linktreeRetry(linkLimiter, () =>
        fetch(`${BASE}/api/v1/profiles/${profileId}/links/${link.id}`, {
          method: "PATCH", headers,
          body: JSON.stringify({ title: link.title, url: link.url }),
        })
      ))
    );
    results.push(...batchResults);
    if (i + batchSize < links.length) await new Promise(r => setTimeout(r, 10_000));
  }
  return results;
}

Error Handling

Issue Cause Fix
429 on link updates Exceeded 30 writes/min per token Reduce batch concurrency to 3
429 on analytics Polling per-link stats too frequently Cache analytics, refresh every 5 min
401 token expired OAuth token TTL exceeded Refresh token before batch operations
404 on link delete Link already removed or archived Skip gracefully, log warning
IP-level 429 Multiple tokens from same IP Spread requests across proxy endpoints

Resources

Next Steps

See linktree-performance-tuning.

信息
Category 编程开发
Name linktree-rate-limits
版本 v20260423
大小 4.39KB
更新时间 2026-04-28
语言