A carefully curated list of awesome Python asyncio frameworks, libraries, software and resources.
The Python asyncio module introduced to the standard library with Python 3.4 provides infrastructure for writing single-threaded concurrent code using coroutines, multiplexing I/O access over sockets and other resources, running network clients and servers, and other related primitives.
Asyncio is not really a brand-new technology however it appears to be very trending since a few years - especially in the Python community and with the release of Python 3.4 in March 2016. Thus, it's pretty hard to keep yourself up-to-date with the most awesome packages out there. Find some of those awesome packages here and if you are missing one we count on you to create an Issue or a Pull Request with your suggestion.
- Web Frameworks
- Message Queues
- Database Drivers
- Networking
- Testing
- Alternative Loops
- Misc
- Writings
- Talks
Libraries to build web applications.
- aiohttp - Http client/server for asyncio (PEP-3156).
- sanic - Python 3.5+ web server that's written to go fast.
- Kyoukai - Fully async web framework for Python3.5+ using asyncio.
- cirrina - Opinionated asynchronous web framework based on aiohttp.
- autobahn - WebSocket and WAMP supporting asyncio and Twisted, for clients and servers.
Libraries to implement applications using message queues.
- aioamqp - AMQP implementation using asyncio.
- aiozmq - Asyncio (pep 3156) integration with ZeroMQ.
- crossbar - Crossbar.io is a networking platform for distributed and microservice applications.
Libraries to connect to databases.
- asyncpg - Fast PostgreSQL Database Client Library for Python/asyncio.
- asyncpgsa - Asyncpg with sqlalchemy core support.
- aiopg - Library for accessing a PostgreSQL database.
- aiomysql - Library for accessing a MySQL database
- aioodbc - Library for accessing a ODBC databases.
- motor - The async Python driver for MongoDB.
- asyncio-redis - Redis client for Python asyncio (PEP 3156).
- aiocouchdb - CouchDB client built on top of aiohttp (asyncio).
- aioes - Asyncio compatible driver for elasticsearch.
- peewee-async - ORM implementation based on peewee and aiopg.
Libraries to communicate in your network.
- AsyncSSH - Provides an asynchronous client and server implementation of the SSHv2 protocol.
Libraries to test asyncio based applications.
- aiomock - A python mock library that supports async methods.
- asynctest - Enhance the standard unittest package with features for testing. asyncio libraries
- pytest-asyncio - Pytest support for asyncio.
Alternative asyncio loop implementations.
- uvloop - Ultra fast implementation of asyncio event loop on top of libuv.
- curio - The coroutine concurrency library.
Other awesome asyncio libraries.
- aiofiles - File support for asyncio.
- aiodebug - A tiny library for monitoring and testing asyncio programs.
- aiomonitor - adds monitor and python REPL capabilities for asyncio application.
- aiozipkin - Distributed tracing instrumentation for asyncio with zipkin
Documentation, blog posts, and other awesome writing about asyncio.
- Official asyncio documentation - Asynchronous I/O, event loop, coroutines and tasks.
- Short well-written intro to asyncio - Generators, Coroutines, Native Coroutines and async/await.
- Async Through the looking Glass - Nice writing about it's worth using asyncio or not for specific use-cases.
- Asynchronous Python - Introduction into asynchronous programming with Python.
People has given awesome talks about asyncio.
- Topics of Interest (Python Asyncio) - Keynote by David Beazley.