An efficient implementation of a rate limiter for asyncio.
This project implements the Leaky bucket algorithm, giving you precise control over the rate a code section can be entered:
from aiolimiter import AsyncLimiter
# allow for 100 concurrent entries within a 30 second window
rate_limit = AsyncLimiter(100, 30)
async def some_coroutine():
async with rate_limit:
# this section is *at most* going to entered 100 times
# in a 30 second period.
await do_something()
It was first developed as an answer on Stack Overflow.
https://aiolimiter.readthedocs.io
$ pip install aiolimiter
The library requires Python 3.9 or newer.
- Python >= 3.9
aiolimiter
is offered under the MIT license.
The project is hosted on GitHub.
Please file an issue in the bug tracker if you have found a bug or have some suggestions to improve the library.
This project uses uv to manage dependencies, testing and releases. Make sure you have installed that tool, then run the following command to get set up:
uv sync
Tests are run with pytest
and tox
. Releases are made managed by a GitHub Actions workflow. Code quality is maintained with ruff
and pyright
, and pre-commit
runs quick checks to maintain the standards set.
A Taskfile is provided that defines specific tasks such as linting, formatting or previewing the documentation:
$ task --list
task: Available tasks for this project:
* default: Default task, runs linters and tests
* dev:format: Runs formatters (aliases: format)
* dev:install-precommit: Install pre-commit into local git checkout
* dev:lint: Runs linters (aliases: lint)
* dev:lint:code: Lint the source code
* dev:lint:renovate: Lint the Renovate configuration file
* dev:test: Run tests (aliases: test)
* dev:tox: Run tests with tox (aliases: tox)
* dev:uv-lock: Updates the uv lock file (aliases: lock)
* dist:build: Build the distribution packages (aliases: dist)
* dist:clean: Remove built distribution packages (aliases: clean)
* dist:publish: Publish package to PyPI (aliases: publish)
* docs:build: Build project documentation (aliases: docs)
* docs:serve: Live preview server for project documentation (aliases: preview)