Rate limiting middleware for Django applications
Add the rate limiter to your django projects’ settings.py and enable a global rate limit for all views in your project:
MIDDLEWARE_CLASSES += ("djlimiter.Limiter",) RATELIMIT_GLOBAL = "10/second; 50/hour"
In one of the apps’ view:
@limit("5/second") def index(request): ... @exempt def ping(request): ...
The above example will result in the following characteristics being applied to the django project:
- A global rate limit of 10 per second, and 50 per hour applied to all routes.
indexroute will have an explicit rate limit of 5/second
pingroute will be exempt from any global rate limits.
Every time a request exceeds the rate limit, the view function will not get called and instead a 429 http error will be raised.
Refer to Recipes for more examples.