To deploy rate limiting rules at the account level, you must create a rate limiting ruleset with one or more rules. Use theRulesets API to create and deploy rate limiting rulesets via API.
At the API level, a rate limiting ruleset is a regularcustom ruleset with one or more rate limiting rules that you create in thehttp_ratelimit
phase. The concept of custom rate limiting ruleset exists in the Cloudflare dashboard to make it clear that you are configuring and deploying rate limiting rules at the account level. This page with API instructions uses the same terminology.
Each rate limiting rule contains aratelimit
object with the rate limiting configuration. Refer toRate limiting parameters for more information on this object and its parameters.
If you are using Terraform, refer toRate limiting rules configuration using Terraform.
To deploy a rate limiting ruleset in your account, follow these general steps:
- Create a rate limiting ruleset (that is, a custom ruleset in the
http_ratelimit
phase) with one or more rate limiting rules. - Deploy the ruleset to theentry point ruleset of the
http_ratelimit
phase at the account level.
The following example creates a rate limiting ruleset with a single rate limiting rule in therules
array.
Required API token permissions
At least one of the followingtoken permissions is required:Account WAF Write
Account Rulesets Write
curl"https://api.cloudflare.com/client/v4/accounts/$ACCOUNT_ID/rulesets"\--requestPOST\--header"Authorization: Bearer$CLOUDFLARE_API_TOKEN"\--json'{"description": "","kind": "custom","name": "My rate limiting ruleset","rules": [{"description": "Rate limit API requests","expression": "(starts_with(http.request.uri.path, \"/my-api/\"))","ratelimit": {"characteristics": ["ip.src","cf.colo.id"],"requests_to_origin": false,"requests_per_period": 30,"period": 60,"mitigation_timeout": 120},"action": "block","action_parameters": {"response": {"status_code": 429,"content_type": "application/json","content": "{ \"error\": \"Your API requests have been rate limited. Wait a couple of minutes and try again.\" }"}},"enabled": true}],"phase": "http_ratelimit"}'
The available characteristics depend on your Cloudflare plan and product subscriptions. Refer toAvailability for more information.
Save the ruleset ID in the response for the next step.
To deploy the rate limiting ruleset, add a rule with"action": "execute"
to thehttp_ratelimit
phase entry point ruleset at the account level.
Invoke theGet an account entry point ruleset operation to obtain the definition of the entry point ruleset for the
http_ratelimit
phase. You will need theaccount ID for this task.
At least one of the followingtoken permissions is required:Required API token permissions
Account WAF Write
Account WAF Read
Account Rulesets Read
Account Rulesets Write
Get an account entry point ruleset curl"https://api.cloudflare.com/client/v4/accounts/$ACCOUNT_ID/rulesets/phases/http_ratelimit/entrypoint"\--requestGET\--header"Authorization: Bearer$CLOUDFLARE_API_TOKEN"{"result":{"description":"Account-level phase entry point","id":"<RULESET_ID>","kind":"root","last_updated":"2024-03-16T15:40:08.202335Z","name":"root","phase":"http_ratelimit","rules":[// ...],"source":"firewall_managed","version":"10"},"success":true,"errors":[],"messages":[]}If the entry point ruleset already exists (that is, if you received a
200 OK
status code and the ruleset definition), take note of the ruleset ID in the response. Then, invoke theCreate an account ruleset rule operation to add anexecute
rule to the existing ruleset deploying the rate limiting ruleset. By default, the rule will be added at the end of the list of rules already in the ruleset.The following request creates a rule that executes the rate limiting ruleset with ID
<RATE_LIMITING_RULESET_ID>
for all Enterprise zones in the account:
At least one of the followingtoken permissions is required:Required API token permissions
Account WAF Write
Account Rulesets Write
Create an account ruleset rule curl"https://api.cloudflare.com/client/v4/accounts/$ACCOUNT_ID/rulesets/$RULESET_ID/rules"\--requestPOST\--header"Authorization: Bearer$CLOUDFLARE_API_TOKEN"\--json'{"description": "Execute rate limiting ruleset","expression": "(cf.zone.plan eq \"ENT\")","action": "execute","action_parameters": {"id": "<RATE_LIMITING_RULESET_ID>"},"enabled": true}'You can only apply rate limiting rulesets to incoming traffic of zones on an Enterprise plan. To enforce this requirement, you must include
cf.zone.plan eq "ENT"
in the expression of theexecute
rule deploying the rate limiting ruleset.If the entry point ruleset does not exist (that is, if you received a
404 Not Found
status code in step 1), create it using theCreate an account ruleset operation. Include a single rule in therules
array that executes the rate limiting ruleset for all incoming requests of Enterprise zones in your account.
At least one of the followingtoken permissions is required:Required API token permissions
Account WAF Write
Account Rulesets Write
Create an account ruleset curl"https://api.cloudflare.com/client/v4/accounts/$ACCOUNT_ID/rulesets"\--requestPOST\--header"Authorization: Bearer$CLOUDFLARE_API_TOKEN"\--json'{"description": "","kind": "root","name": "Account-level phase entry point","rules": [{"action": "execute","expression": "(cf.zone.plan eq \"ENT\")","action_parameters": {"id": "<RATE_LIMITING_RULESET_ID>"}}],"phase": "http_ratelimit"}'
For examples of rate limiting rule definitions for the API, refer to thezone-level API documentation.
Use the different operations in theRulesets API to work with the ruleset you just created and deployed. The following table has a list of common tasks for working with rate limiting rulesets at the account level:
Task | Procedure |
---|---|
Get list of rate limiting rulesets | Use theList account rulesets operation and search for rulesets with For more information, refer toList existing rulesets. |
List all rules in a rate limiting ruleset | Use theGet an account ruleset operation with the rate limiting ruleset ID to obtain the list of configured rate limiting rules and their IDs. For more information, refer toView a specific ruleset. |
Update a rate limiting rule | Use theUpdate an account ruleset rule operation. You will need to provide the rate limiting ruleset ID and the rule ID. For more information, refer toUpdate a rule in a ruleset. |
Delete a rate limiting rule | Use theDelete an account ruleset rule operation. You will need to provide the rate limiting ruleset ID and the rule ID. For more information, refer toDelete a rule in a ruleset. |
For more information on the different rate limiting parameters you can configure in your rate limiting rules, refer toRate limiting parameters.
- Resources
- API
- New to Cloudflare?
- Products
- Sponsorships
- Open Source
- Support
- Help Center
- System Status
- Compliance
- GDPR
- Company
- cloudflare.com
- Our team
- Careers
- © 2025 Cloudflare, Inc.
- Privacy Policy
- Terms of Use
- Report Security Issues
- Trademark