Skip to main content

Rate Limit Migration

Published: January 25, 2024

Last Update: December 04, 2024

 

Background

The Anthology Developer Portal plays a crucial role in the integrations with the Anthology product portfolio, as such it handles millions of requests each day, making the implementation of a rate limit mechanism essential.

Rate limiting is a mechanism used in the web applications to control the traffic flow and the resources utilization. The limit is set by a default value, which is the number of API requests that can be made each day from applications that are registered to your developer group by default, this is set to 10,000 calls every 24 hours.

If you need a higher rate limit, please review our guide.

Migration

In our ongoing effort to optimize and enhance our system's performance, we are transitioning our rate limit algorithm. This change aims to improve scalability, better manage of burst traffic and enhance the control over our system resources, all while providing a consistent and reliable experience for our users.

FAQ

  • Is this change going to impact any of my applications?

    No, the refresh frame will remain at 24 hours and the default rate limit will continue to be 10,000 calls. Any existing rate limit variations requested by clients and partners will also be maintained.

  • When is this change going to be applied?

    This change is planned to be deployed in the June release on 06/04/2024.

  • What is the new rate limit algorithm that is going to be implemented?

    We are now using the token bucket algorithm, which allows applications to have a better control over burst traffic. This will also enable us to improve the refresh rate in the future.

  • What is a token?

    You can think of a token as a coin that allows you to make a request. Once you run out of tokens, you won't be able to make any more requests and a 429 HTTP error will be returned.

  • Will there be any changes to the headers of the request?

    There won't be many significant changes in the returned headers. The only major change is that X-Rate-Limit-Reset will be replaced with Retry-After, but it will function in the same way returning in how many seconds you will have more tokens to make a request.

HTTP HeaderDescription
Retry-AfterThe remaining time in seconds before the bucket is filled with new tokens to make a request
X-Rate-Limit-LimitThe rate limit ceiling for the given development group
X-Rate-Limit-RemainingThe number of requests left for the 24-hour period for the development group

The X-Rate-Limit-Reset header was removed because the replenishment no longer occurs according to a fixed global clock. It occurs 24-hours after the first request. Please note that the current 24 hours refresh period may be shortened in the future.