Skip to main content

A python toolkit to enforce API rate limit on the backend

Project description

API Throttler

Build Release PyPi

A Python toolkit to enforce API rate limit on the backend. The toolkit enable the service backend to limit the number of API calls in a specified period, e.g., 15 API calls per 900 seconds. There are four throttler classes in the toolkit:

  • FixedWindowThrottler
  • SlidingWindowThrottler
  • FixedWindowThrottlerRedis
  • SlidingWindowThrottlerRedis

The first two throttler classes use local storage to save throttler data (e.g., API calls that have been served and their timestamps), while the last two throttler classes use a Redis server to store throttler information. The difference between the fixed window and sliding window throttlers is the fixed window throttler uses the timestamp when the first feasible request is served as the starting timestamp to determine the number of allowed API calls in the following period, while the sliding window throttler uses the current timestamp minus the specified period as the starting timestamp to calculate the number of allowed API calls. The advantage of fixed window throttler is its simplicity, but there could be many API calls allowed if they are at the end of last period and the beginning of the current period. On the other hand, the sliding window throttler could resolve this issue, but it takes more memory.

Usage

To use this API throttler toolkit, first install it using pip:

pip install api-throttler

Then, import the package in your python script and use appropriate throttler classes:

import time

from api_throttler import Throttler, FixedWindowThrottler, SlidingWindowThrottler


# Limit 3 calls per 10 seconds
fixed_window_throttler = FixedWindowThrottler(calls=3, period=10)
sliding_window_throttler = SlidingWindowThrottler(calls=3, period=10)


def call_api(throttler: Throttler, key: str = 'some_string_key'):
    if not throttler.is_throttled(key):
        print('API call is NOT throttled')
    else:
        print('API call is throttled')


print('Using fixed window API throttler')
for i in range(20):
    print(f'This is the {i}-th second')
    # Call API in the following i-th seconds
    if i in {0, 8, 9, 10, 11, 12}:
        call_api(fixed_window_throttler)
    time.sleep(1)

print('-'*40)

print('Using sliding window API throttler')
for i in range(20):
    print(f'This is the {i}-th second')
    if i in {0, 8, 9, 10, 11, 12}:
        call_api(sliding_window_throttler)
    time.sleep(1)

In the above example, the data of the throttler is saved in local memory. If you would like to save it in a redis server, you can use the FixedWindowThrottlerRedis and SlidingWindowThrottlerRedis classes. The following scripts shows how to use the two classes using fake redis:

import time

import fakeredis
from api_throttler import Throttler, FixedWindowThrottlerRedis, SlidingWindowThrottlerRedis

cache = fakeredis.FakeStrictRedis()

# Limit 3 calls per 10 seconds
fixed_window_throttler = FixedWindowThrottlerRedis(calls=3, period=10, cache=cache)
sliding_window_throttler = SlidingWindowThrottlerRedis(calls=3, period=10, cache=cache)


def call_api(throttler: Throttler, key: str = 'some_string_key'):
    if not throttler.is_throttled(key):
        print('API call is NOT throttled')
    else:
        print('API call is throttled')


print('Using fixed window API throttler')
for i in range(20):
    print(f'This is the {i}-th second')
    # Call API in the following i-th seconds
    if i in {0, 8, 9, 10, 11, 12}:
        call_api(fixed_window_throttler)
    time.sleep(1)

print('-'*40)

print('Using sliding window API throttler')
for i in range(20):
    print(f'This is the {i}-th second')
    if i in {0, 8, 9, 10, 11, 12}:
        call_api(sliding_window_throttler)
    time.sleep(1)

If you would like to try a real example using API served by a Flask app and a redis server, please try to run the app.py using Docker by typing the following command in your terminal:

docker-compose up --build

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

api_throttler-0.3.1.tar.gz (5.4 kB view details)

Uploaded Source

Built Distribution

api_throttler-0.3.1-py2.py3-none-any.whl (6.7 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file api_throttler-0.3.1.tar.gz.

File metadata

  • Download URL: api_throttler-0.3.1.tar.gz
  • Upload date:
  • Size: 5.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.6.1 requests/2.25.1 setuptools/49.2.1 requests-toolbelt/0.9.1 tqdm/4.55.0 CPython/3.9.1

File hashes

Hashes for api_throttler-0.3.1.tar.gz
Algorithm Hash digest
SHA256 814e88e72dad61fea7d3f9c3bb5837a4efa3d841c73c061ab849f9cbeb4df64c
MD5 8494e3206550ee35104c5b86327ebe0e
BLAKE2b-256 8cda95546edc514fdc30aef209a0f3f3ca55fc1ec9b92f32f0c158f8aca6d508

See more details on using hashes here.

File details

Details for the file api_throttler-0.3.1-py2.py3-none-any.whl.

File metadata

  • Download URL: api_throttler-0.3.1-py2.py3-none-any.whl
  • Upload date:
  • Size: 6.7 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.6.1 requests/2.25.1 setuptools/49.2.1 requests-toolbelt/0.9.1 tqdm/4.55.0 CPython/3.9.1

File hashes

Hashes for api_throttler-0.3.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 acfcd7ce018ecb2a1df15db319248abde0a0a75aed3b3d53d11171699da7d461
MD5 69961944dbf7f56c462a0b4e06bca487
BLAKE2b-256 b19c3da2c395c6f7abad2cd6b016ff66a70fe011684844cf2d49a499bde2e436

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page