A fixed window rate limiting based on Redis
Project description
A fixed window rate limiting based on Redis
Requirements
Python >= 3.6
Redis >= 2
Installation
$ pip install redis-ratelimit
NB! redis-ratelimit requires a running Redis server. See Redis’s quickstart for installation instructions.
Getting started
Assuming you have Flask installed:
from flask import Flask, jsonify
from redis_ratelimit import ratelimit
app = Flask(__name__)
@app.route('/')
@ratelimit(rate='10/m', key='ccc')
@ratelimit(rate='2/s', key='ccc')
def index():
return jsonify({'status': 'OK'})
This will allow a total of 10 requests in any given minute, but no faster than 2 requests a second.
Notes
License
MIT
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
redis-ratelimit-1.0.1.tar.gz
(2.8 kB
view hashes)
Built Distribution
Close
Hashes for redis_ratelimit-1.0.1-py2.py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 84e90bdd080b0b3a2885509524733895e4d036daebbed016f77ea029d1bdd888 |
|
MD5 | 0573994d50d5e55823f6d0eeb86b92d3 |
|
BLAKE2b-256 | 226c33709ac38b289b621196a9f35b04085c904bfe3fdd52e9bb964344a395fd |