Technical Limits

    Our shared-service infrastructure is built to maintain steady performance for every customer, thanks to carefully set technical limits. If any API call or CMS action goes over these boundaries, it'll trigger an error message. Should your project require higher limits, get in touch with us to discuss further.

    Here are the technical limits currently in place for the CMA:

    • Maximum Record size: 300 KB, including content in nested blocks (assets and linked records do not count toward the limit).

      • Please note that the maximum record size allowed by your plan may exceed the default 300KB limit. To confirm whether your plan supports a larger maximum record size, check the 'Plan and Billing' section in your Account dashboard.

    • Number of blocks per record: 600

    • Maximum depth for nested blocks: 6 levels

    • Number of concurrent editors per record: 1 (with presence indicator and record locking, read more)

    • Assets upload: Max size of 1 GB per asset

    Rate limits

    API rate limits specify the number of requests a client can make to DatoCMS APIs in a specific time frame.

    By default the Management API enforces rate limits of 60 requests per 3 seconds. Higher rate limits may apply depending on your current plan.

    In the following list you can find all the headers returned in every response by the Content Management API which give a client information on rate limiting:

    • X-RateLimit-Limit: the maximum amount of requests which can be made in 3 seconds.

    • X-RateLimit-Remaining: the remaining amount of requests which can be made until the next 3-seconds reset.

    • X-RateLimit-Reset: if present, indicates the number of seconds until the next request can be made.

    When a client gets rate limited, the API responds with the 429 Too Many Requests HTTP status code and sets the value X-RateLimit-Reset header to an integer larger than 0 specifying the time before the limit resets and another request will be accepted.

    Official clients and rate limits

    Our Javascript client already manages rate limit errors for you with a retry mechanism! If it encounters a 429 status code, the promise won't be rejected. The client will repeat the requests until the API stops returning 429 status codes, and only then will the promise will be resolved with success.

    429 Status Responses in DatoCMS Shared Infrastructure

    Even when you are operating within your rate limits, there is a possibility of encountering a 429 status code in situations of high system load if your project is hosted on the DatoCMS shared infrastructure or medium-density infrastructure.

    Nevertheless, it's essential to acknowledge that this occurrence is rare, and our official clients are equipped with an automatic retry mechanism to seamlessly handle such situations.

    Reaching your plan monthly API calls limit

    Every DatoCMS plan offers a number of API requests per month. What happens you exceed the included quota?

    • If your project is under a free plan, API responses will be temporarily disabled until the beginning of the following calendar month, unless you switch to a paid plan.

    • If your project is under a paid plan, you will pay an additional cost for the additional usage you made of the API.

    For more details, check our Plans, billing and pricing page.