Python下篇 3. 异步编程生态

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 Tair(兼容Redis),内存型 2GB
简介: Python下篇 3. 异步编程生态

1. 前言



协程中不能写阻塞的代码因为异步编程遵旨就是要异步,所有的都要异步,所以就不能使用阻塞的代码和库,如requests, pymysql等,非得使用也可以,异步+多线程的方式仍然有效(在前面文章中讲解过了)。但是我们都希望所有的代码都可以使用异步完成,这就促使开发者必须基于异步去改造或者创造新的库或者框架等,目前异步编程生态圈正在逐步完善,我们完全可以使用它们。


2. 异步web框架



  1. Tornado

Tornado在2009年发布,从一开始就提供有异步编程的功能。Tornado不仅仅是Web框架,同时它内置了很多异步模块,可用于自己构建异步应用。这些模块包括:

  • 协同程序和其他原语(tornado.gen,tornado.locks,tornado.queues等)
  • 网络模块(tornado.ioloop,tornado.iostream等)
  • 异步服务器和客户端(tornado.httpserver,tornado.httpclient等)

通过这些模块,Tornado构建了自己的异步Web框架模块。


  1. FastAPI

FastAPI似乎是异步Python框架里功能、文档最丰富的框架。它语法简单,自动生成API文档,而且性能在某些情况下可以与Go相匹配。总而言之,我真的有一种感觉,FastAPI将成为Python的顶级异步框架。


  1. Sanic

Sanic只支持3.6以上Python版本,支持通用的async/await语法,开箱即用,因此你无需阅读大量文档就可以写出你的一个HTTP处理器。

Sanic可以说是Python世界中最流行和最受欢迎的异步框架。它具有你项目中需要的所有功能:路由,中间件,Cookie,版本控制,蓝图,基于类的视图,静态文件,流,sockets,此外你还可以集成模板,数据库驱动,文件I / O,队列等等。


3. 异步库



  1. Aiohttp

Aiohttp是基于python和asyncio的客户端/服务端异步网络请求库,对应于同步网络请求库是requests,所以在异步编程中想要请求网络接口,那么必须使用异步网络库,而Aiohttp是首选的。


  1. Aiomysql

Aiomysql是基于python和asyncio的异步mysql客户端库,它依赖并重用Pymysql大量功能,所以你可以在异步编程中像使用同步编程的方式编写异步代码。


  1. Aioredis

Aioredis是基于Python和asyncio的异步redis客户端库,里面也是复用大量redis的操作,所以在创建redis pool的时候一定要用异步的方式去创建。


4. 异步IO



  1. gevent

greenlet + libevent(后来是libev或libuv)。通过协程(greenlet)和事件循环库(libev,libuv)实现的gevent使用很广泛。


  1. twisted

是事件驱动的网络库。


  1. asyncio

Python3.4加入了asyncio库,使得Python有了支持异步IO的官方库。这个库,底层是事件循环(EventLoop),上层是协程和任务。asyncio自从3.4版本加入到最新的3.7版一直在改进中。


  1. async/await

Python3.5引入了两个新的关键字await和async用来替换@asyncio.coroutine和yield from,从语言本身来支持异步IO。从而使得异步编程更加简洁,并和普通的生成器区别开来。


  1. uvloop

uvloop是用Cython写的,基于libuv这个C语言实现的高性能异步I/O库。asyncio自己的事件循环是用Python写的,用uvloop替换asyncio的事件循环让异步程序运行速度更快,并且使用也相当简洁。


5. 小结



以上所有异步知识没必要都深入了解,只需要关心自己需要用到的就可以了,因为技术在不断更迭,等你花时间都掌握了之后,这个时候如果一旦出现新的技术可以替代老技术的时候,那么你之前积累的将会无用武之地,所以按照需要学习,把时间花在底层和长期技术投资上,这样不管后来技术如何变迁,透过表象看本质都是一样的。

相关实践学习
基于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
相关文章
|
13天前
|
Python
Python中的异步编程:使用asyncio和aiohttp实现高效网络请求
【10月更文挑战第34天】在Python的世界里,异步编程是提高效率的利器。本文将带你了解如何使用asyncio和aiohttp库来编写高效的网络请求代码。我们将通过一个简单的示例来展示如何利用这些工具来并发地处理多个网络请求,从而提高程序的整体性能。准备好让你的Python代码飞起来吧!
35 2
|
20天前
|
数据采集 数据安全/隐私保护 开发者
非阻塞 I/O:异步编程提升 Python 应用速度
非阻塞 I/O:异步编程提升 Python 应用速度
|
17天前
|
调度 开发者 Python
Python中的异步编程:理解asyncio库
在Python的世界里,异步编程是一种高效处理I/O密集型任务的方法。本文将深入探讨Python的asyncio库,它是实现异步编程的核心。我们将从asyncio的基本概念出发,逐步解析事件循环、协程、任务和期货的概念,并通过实例展示如何使用asyncio来编写异步代码。不同于传统的同步编程,异步编程能够让程序在等待I/O操作完成时释放资源去处理其他任务,从而提高程序的整体效率和响应速度。
|
11天前
|
数据采集 调度 Python
探索Python中的异步编程:从基础到高级
【10月更文挑战第36天】在Python的世界中,异步编程是提升程序性能和响应速度的重要工具。本文将带你深入了解Python异步编程的核心概念,包括事件循环、协程与异步IO,并逐步展示如何在实际项目中应用这些概念来编写更高效、可扩展的代码。通过理论讲解与实践案例的结合,我们将一起构建一个异步Web爬虫,以直观感受异步编程的强大之处。
|
13天前
|
数据库 Python
异步编程不再难!Python asyncio库实战,让你的代码流畅如丝!
在编程中,随着应用复杂度的提升,对并发和异步处理的需求日益增长。Python的asyncio库通过async和await关键字,简化了异步编程,使其变得流畅高效。本文将通过实战示例,介绍异步编程的基本概念、如何使用asyncio编写异步代码以及处理多个异步任务的方法,帮助你掌握异步编程技巧,提高代码性能。
49 4
|
26天前
|
开发者 Python
探索Python中的异步编程
【10月更文挑战第20天】在本文中,我们将深入探讨Python的异步编程,这是一种能够提高程序执行效率的技术。我们将通过代码示例和实际应用场景来理解其工作原理和应用价值。无论你是初学者还是有经验的开发者,这篇文章都将为你提供新的视角和实用技巧。
|
22天前
|
数据库 开发者 Python
“Python异步编程革命:如何从编程新手蜕变为并发大师,掌握未来技术的制胜法宝”
【10月更文挑战第25天】介绍了Python异步编程的基础和高级技巧。文章从同步与异步编程的区别入手,逐步讲解了如何使用`asyncio`库和`async`/`await`关键字进行异步编程。通过对比传统多线程,展示了异步编程在I/O密集型任务中的优势,并提供了最佳实践建议。
17 1
|
24天前
|
调度 开发者 Python
异步编程在Python中的应用:Asyncio和Coroutines
异步编程在Python中的应用:Asyncio和Coroutines
20 1
|
26天前
|
关系型数据库 MySQL 数据处理
探索Python中的异步编程:从asyncio到异步数据库操作
在这个快节奏的技术世界里,效率和性能是关键。本文将带你深入Python的异步编程世界,从基础的asyncio库开始,逐步探索到异步数据库操作的高级应用。我们将一起揭开异步编程的神秘面纱,探索它如何帮助我们提升应用程序的性能和响应速度。
|
30天前
|
调度 开发者 Python
探索Python中的异步编程:从基础到实践
在本文中,我们将深入探讨Python的异步编程世界。从asyncio库的基本概念出发,我们将逐步构建起对异步编程的理解,并探索如何在实际项目中应用这些技术。本文不仅涵盖了异步编程的基础知识,还提供了实用的代码示例,旨在帮助读者在Python中有效地使用异步编程,以提高应用程序的性能和响应能力。
下一篇
无影云桌面