The ingest API (apps/ingest) is the write path: it receives batches of traces from the SDK, prices each span, and persists them. Most users never call it directly — foglamp does — but it’s a plain HTTP+JSON API you can target from any language.
A 429 is returned in two distinct cases, and they call for different handling:
Per-key rate limit — too many requests per second for one key. The response includes a Retry-After header; back off and retry after it.
Plan quota exceeded — the org’s monthly span quota is used up. This is a billing condition, not rate limiting: it carries no Retry-After, and retrying will not succeed until the plan is upgraded or the quota resets.
The foglamp SDK does not retry failed batches — a failed flush is routed to onError and the batch is dropped (telemetry never blocks or retries into your app). If you call the ingest API directly, implement your own retry with backoff for transport errors and rate-limit 429s, and treat a quota 429 as terminal.
The body is a versioned batch — version: "v1" plus a traces array (1–1000 traces, each with 1–2000 spans). See the data model for field semantics, or the Ingest endpoints in the sidebar for the full schema and a live playground.