Throttler for asyncio Python
Project description
aiothrottler
Throttler for asyncio Python
Installation
pip install aiothrottler
Usage
Create a shared Throttler
, passing a minimum interval, e.g. 0.5
seconds
throttler = Throttler(min_interval=0.5)
and then just before the piece(s) of code to be throttled, call this and await
its result.
await throttler()
# There will be a gap of at least 0.5 seconds
# between executions reaching this line
Example: multiple tasks throttled
import asyncio
import time
from aiothrottler import Throttler
async def main():
throttler = Throttler(min_interval=0.5)
await asyncio.gather(*[
worker(throttler) for _ in range(10)
])
async def worker(throttler):
await throttler()
# Interval of at least 0.5 seconds between prints
# even though all workers started together
print(time.time())
loop = asyncio.get_event_loop()
loop.run_until_complete(main())
loop.close()
Example: single task throttled/smoothed
import asyncio
import random
import time
from aiothrottler import Throttler
async def main():
throttler = Throttler(min_interval=0.5)
for _ in range(10):
await throttler()
# Interval of at least 0.5 seconds between prints
# even though each sleep is random
print(time.time())
await asyncio.sleep(random.random())
loop = asyncio.get_event_loop()
loop.run_until_complete(main())
loop.close()
Differences to alternatives
-
The API features a function to call to
await
its result [some use a context manager] -
The API is imperative [some use a functional approach/higher-order function]
-
No polling is used [some use polling internally]
-
A minimum interval between resolutions is used to throttle [rather that a max resolutions per time interval, which can cause an irregular pattern of resolutions]
-
The tests cover edge cases, such as asserting on throttling after tasks being throttled have been cancelled [some alternatives do not]
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
Built Distribution
Hashes for aiothrottler-0.0.15-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8a59948efeab54079d33e54869d17c1905be3e6ae87e7e3535b7a0fcaaf7e2e0 |
|
MD5 | 59f3ecb22ba1d5135d115c1c6b972220 |
|
BLAKE2b-256 | da8fa93054aa7870e2074ae538ed04213cd5d716c54b322178f99ad672326400 |