Identifying rate limits
Recognize the rate limits that apply to App Store Server API endpoints and handle them in your code.
Overview
The App Store Server API limits the number of requests that you can submit to each endpoint within a specified timespan. The request limits apply per app.
The following table lists the rate limits for each endpoint in the production environment, expressed in requests per second. The system enforces rate limits on an hourly basis.
Endpoint | Rate limit (per second) |
|---|---|
50 | |
50 | |
50 | |
50 | |
50 | |
50 | |
50 | |
50 | |
50 | |
20 | |
20 | |
10 | |
10 | |
10 | |
Extend Subscription Renewal Dates For All Active Subscribers | 1 |
1 | |
1 |
The rate limits in the sandbox environment are 10% of the limits in the table above.
The App Store server may make adjustments to reduce or increase these rate limits as needed at any time.
Handle exceeded rate limits gracefully
If you exceed a per-hour limit, the API rejects the request with an HTTP 429 response, with a RateLimitExceededError in the body. Consider the following as you integrate the API:
If you periodically call the API, throttle your requests to avoid exceeding the per-hour limit for an endpoint.
Manage the
HTTP429RateLimitExceededError in your error-handling process. For example, log the failure and queue the job to process it again at a later time.Check the
Retry-Afterheader if you receive theHTTP429error. This header contains a UNIX time, in milliseconds, that informs you when you can next send a request.