Skip to main content

choke: simple implementation of throttling mechanism.

Project description

License: MIT Build Status

choke is a package implementing a trivial to use general purpose throttling mechanism. The basic workflow with choke is as follows:

  1. Create manager - an object responsible for keeping track of timestamps when some events (think: calls to your functions) occur.

  2. Instruct manager to “choke” some callables, i.e. define maximum number of calls that can occur per given time window.

  3. Use your callables as usual, keeping in mind that when the above defined limit is exceeded, the choked callable will raise CallLimitExceededError.

Here is an example containing everything you need to use choke:

from time import sleep
from redis import StrictRedis
from choke import RedisChokeManager, CallLimitExceededError

REDIS = StrictRedis() # Tweak this to reflect your setup
CHOKE_MANAGER = RedisChokeManager(redis=REDIS)

# Example configuration: enforce limit of no more than 10 calls in two seconds window
@CHOKE_MANAGER.choke(limit=10, window_length=2)
def foo(x, y):
    """Just print something to show that foo was called."""
    print(f'foo called with ({x}, {y})')

if __name__ == '__main__':
    # We expect pattern of 10 successes followed by 10 failures followed again by 10 successes
    # Some deviations from this pattern may obviously occur as calling foo takes nonzero time
    for i in range(30):
        try:
            foo(i, y=i ** 2)
        except CallLimitExceededError:
            print('Foo not called. Limit exceeded!')
        sleep(0.1)

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

choke-0.1.2.tar.gz (7.1 kB view details)

Uploaded Source

File details

Details for the file choke-0.1.2.tar.gz.

File metadata

  • Download URL: choke-0.1.2.tar.gz
  • Upload date:
  • Size: 7.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.32.1 CPython/3.6.7

File hashes

Hashes for choke-0.1.2.tar.gz
Algorithm Hash digest
SHA256 73312fe55de02f838c2b4c2b0f4faae549ef97dbe78efd6e50e5377ac74bf619
MD5 512d4b8026a965ad0f9c61f3136c10ac
BLAKE2b-256 10153e465780f8f042a45c636c86efd46288c16a0a5fd6304bf4cfb2c18d98ac

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