Awesome Asyncio 《碉堡的Asyncio·中文版》

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Tair(兼容Redis),内存型 2GB
简介: 转一篇关于Asyncio的资源帖。基本涵盖了基于Asyncio的Python生态,非常适合用Python编写高性能服务。可以和之前转的驹神的文章结合看。

转一篇关于Asyncio的资源帖。基本涵盖了基于Asyncio的Python生态,非常适合用Python编写高性能服务。可以和之前转的驹神的文章结合看。如果想让Python技能更上一层楼,强烈建议好好学习下这个资源列表!

Awesome-Asyncio-CN

Awesome-Asyncio-CN

Awesome-Asyncio-CN Github 网址

Python Asyncio 精选资源列表,囊括了网络框架,库,软件等资源

Awesome-asyncioTimo Furrer 发起并维护的 Python Asyncio 资源列表。本项目是其中文版,在这里,收集了大量的 Asyncio 的最棒、最新的资源,供大家探索 Python 异步编程世界。

Python 3.4 引入了 Asyncio 模块作为标准库,通过协程、多路 I/O 访问 Socket 和其他资源来编写单线程并发代码,并在网络客户端与服务器上运行。Asyncio 内置了对异步 I/O 的支持,其编程模型类似于消息循环,从 Asyncio 模块可以直接获取 EventLoop 引用,再把需要执行的协程放到 EventLoop 中执行,就实现了异步 I/O。Asyncio 是由 Python 之父 Guido 领导的项目,该项目被命名为 Tulip(郁金香)。

Asyncio 并不是新出现的黑科技,一些社区有名的第三库如 Twisted、gevent 早就推出了异步编程模型。不过,自从 2016 年 3 月,Python 3.4 推出以后,这两年来,Asyncio 变得越来越流行,并且特别受到 Python 社区追捧。

贡献代码

欢迎大家为列表贡献高质量的新资源,提交 PR 时请参照以下要求

  • 注明推荐理由

  • 确保项目相对活跃

目录

Web框架

构建 Web 应用的库

  • aiohttp - 支持 Asyncio (PEP-3156) 的 HTTP 客户端/服务端网络库。

  • sanic - Python 3.5+ Web 服务器,主打速度与性能。

  • Quart - 支持 Asyncio 的 Web 微框架,使用与 Flask 相同的 API。

  • Kyoukai - 使用 Asyncio 编写的 Python3.5+ 完全异步 Web 框架。

  • cirrina - 基于 aiohttp 的异步 Web 框架。

  • autobahn - 支持 Asyncio 与 Twisted 的 WebSocket 及 WAMP,用于客户端与服务端。

  • websockets - Python 构建的 WebSocket 客户端/服务端的库,致力于简洁、正确地编写代码。

  • Tornado - 高性能 Web 框架以及异步网络库。

  • Japronto! - 基于 uvloop 和 picohttpparse 构建的实验性 HTTP 工具箱。

消息队列

使用消息队列执行应用的库

  • aioamqp - 使用 Asyncio 异步执行 AMQP。

  • aiozmq - 集成了 Asyncio (pep 3156) 的 ZeroMQ。

  • crossbar - Crossbar.io 是提供分布式和微服务应用的网络平台。

数据库驱动

数据库的驱动库

  • asyncpg - 快速访问 PostgreSQL 数据库客户端的异步驱动。

  • asyncpgsa - 提供 Sqlalchemy Core 支持的 Asyncpg。

  • aiopg - 访问 PostgreSQL 数据库的异步驱动。

  • aiomysql - 访问 MySQL 数据库的异步驱动。

  • aioodbc - 访问 ODBC 数据库的异步驱动。

  • motor - 访问 MongoDB 数据库的异步驱动。

  • aioredis - aio-libs 提供的异步 Redis 客户端 (PEP 3156)。

  • asyncio-redis - 访问 Redis 客户端 (PEP 3156)的异步驱动。

  • aiocouchdb - 基于 aiohttp (Asyncio) 构建的 CouchDB 客户端。

  • aioinflux - 基于 aiohttp 构建的 InfluxDB 客户端。

  • aioes - 兼容 elasticsearch 的 Asyncio 驱动。

  • peewee-async - 基于 peewee 和 aiopg 实现的 ORM。

  • GINO - 基于 SQLAlchemy Core 和 asyncpg 方言的轻量级 Python 异步 ORM。

  • aiocache - 支持多个后端 (Memory、Redis 和 Memcached) 的 Asyncio 缓存管理器。

  • aiomcache - 访问 Memcached 的 Asyncio(PEP 3156) 驱动库。

网络

网络通讯库

  • AsyncSSH - 提供执行 SSHv2 协议的异步客户端/服务端。

  • asks - 与 requests 接口相似的异步 HTTP 库。

  • aioftp - 基于 Asyncio 的 ftp 服务。

  • aiodns - 简单的 Asyncio DNS 服务解析器。

  • websockets 构建于 Asyncio 之上的异步 websockets 库。

测试

测试 Asyncio 应用程序的库

  • aiomock - 支持异步的 Python mock 库。

  • asynctest - 一个增强标准 unittest 包的测试库。

  • pytest-asyncio - 支持 Asyncio 的 Pytest 库。

  • aioresponses - 一个适用于 aiohttp 的模拟请求库。

备选事件循环

备选的 Asyncio 循环库

  • uvloop - 基于 libuv 实现的 Asyncio 事件循环库。

  • curio - 协程并发库。

  • trio - 人性化的,Pythonic 的异步 IO 库。

并行

并行异步编程的库

  • aioprocessing - 结合 multiprocessing 与 Asyncio 的进程库,支持 Python3.4+。

  • aiomultiprocess - 进一步提升异步性能的多进程库。

其他

未归类的优秀 Asnycio 库

  • aiofiles - 基于 Asyncio,支持文件异步操作。

  • aiodebug - 用于监控和测试 Asyncio 程序的微型库。

  • aiorun - 提供处理通用 Asyncio 样板,启动和关闭事件驱动的 run 函数。

  • aiozipkin - 使用 zipkin 的分布式 Asyncio 追踪测量仪。

  • faust - 纯 Python 的流处理库,用于处理流数据和事件。

  • paco - 协程驱动的异步编程的工具库 (Python3.4+)。

文献

关于 Asyncio 的文档、博客等文献

演讲

关于 Asyncio 的主题演讲

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
8月前
|
人工智能 自然语言处理 前端开发
Python潮流周刊#7:我讨厌用 asyncio
Python潮流周刊#7:我讨厌用 asyncio
62 0
|
8月前
|
人工智能 测试技术 开发者
Python 潮流周刊#15:如何分析 FastAPI 异步请求的性能?
Python 潮流周刊#15:如何分析 FastAPI 异步请求的性能?
253 2
|
2月前
|
API 开发者 Python
探索Python中的异步编程:Asyncio与Tornado的对决
在这个快节奏的世界里,Python开发者面临着一个挑战:如何让代码跑得更快?本文将带你走进Python异步编程的两大阵营——Asyncio和Tornado,探讨它们如何帮助我们提升性能,以及在实际应用中如何选择。我们将通过一场虚拟的“对决”,比较这两个框架的性能和易用性,让你在异步编程的战场上做出明智的选择。
|
2月前
|
数据库 Python
异步编程不再难!Python asyncio库实战,让你的代码流畅如丝!
在编程中,随着应用复杂度的提升,对并发和异步处理的需求日益增长。Python的asyncio库通过async和await关键字,简化了异步编程,使其变得流畅高效。本文将通过实战示例,介绍异步编程的基本概念、如何使用asyncio编写异步代码以及处理多个异步任务的方法,帮助你掌握异步编程技巧,提高代码性能。
90 4
|
3月前
|
中间件 API 调度
深入探究 Python 异步编程:利用 asyncio 和 aiohttp 构建高效并发应用 精选
深入探究 Python 异步编程:利用 asyncio 和 aiohttp 构建高效并发应用 精选
36 2
|
3月前
|
监控 Python
探索Python中的异步编程:Asyncio模块的魔力
在这篇文章中,我们将深入探讨Python的Asyncio模块,这是Python异步编程的核心。我们将一起揭开异步编程的神秘面纱,学习如何使用async和await关键字来编写非阻塞代码,以及如何利用异步编程提高应用程序的性能。
|
3月前
|
Python
告别阻塞,拥抱未来!Python 异步编程 asyncio 库实战指南!
高效处理并发任务对提升程序性能至关重要,Python 的 `asyncio` 库提供了强大的异步编程支持。通过 `async/await` 关键字,可以在等待操作完成时不阻塞程序执行,显著提高效率和响应性。`asyncio` 支持定义异步函数、创建任务、等待多个任务完成等功能,并能结合第三方库如 `aiohttp` 实现异步网络请求。此外,它还支持异常处理,确保异步代码的健壮性。借助 `asyncio`,您可以轻松构建高性能、响应迅速的应用程序。
60 0
|
6月前
|
数据采集 数据库 Python
Python并发编程新篇章:asyncio库使用全攻略,轻松驾驭异步世界!
【7月更文挑战第11天】Python的asyncio开启异步编程时代,通过案例展示如何用它和aiohttp构建并发爬虫。安装aiohttp后,定义异步函数`fetch`进行HTTP请求,返回状态码和内容长度。在`main`中,并发执行多个`fetch`任务,利用`asyncio.gather`收集结果。使用`async with`管理HTTP会话资源,确保释放。通过这种方式,爬虫性能大幅提升,适用于高并发场景。学习asyncio是提升并发性能的关键。
81 14
|
6月前
|
API 开发者 Python
从理论到实践,Python asyncio库让你成为异步编程的王者!
【7月更文挑战第11天】Python的asyncio库助力异步编程,通过事件循环实现非阻塞并发。定义async函数,如`fetch_url`,用await处理异步操作。在main函数中,利用`asyncio.gather`并发执行任务。进阶应用涉及并发控制(如`asyncio.Semaphore`)和异常处理,使asyncio成为高并发场景下的得力工具。开始探索,掌握asyncio,成为异步编程专家!
67 3
|
6月前
|
数据采集 数据库连接 调度
从菜鸟到大师:掌握Python asyncio库,并发编程不再是梦!
【7月更文挑战第10天】Python的asyncio库简化了异步编程,通过事件循环和协程实现非阻塞I/O,提升效率。从`async def`定义异步函数到`await`等待操作,如在`main`函数中并发调用`say_hello`。深入学习涉及自定义协程、异步上下文管理器和信号量。结合如aiohttp,能构建高性能并发应用,实现高效的Web服务。开始你的asyncio之旅,成为并发编程专家!**
106 0