python asyncio和celery对比_asyncio 并发编程(一)

Python2 时代高性能的网络编程主要是 Twisted、Tornado 和 Gevent 这三个库,但是它们的异步代码相互之间既不兼容也不能移植。Gvanrossum 希望在 Python 3 实现一个原生的基于生成器的协程库,其中直接内置了对异步 IO 的支持,这就是 asyncio,它在 Python 3.4 被引入到标准库。

并发对比

asyncio 使用单线程、单个进程的方式切换(通常程序等待读或写数据时就是切换上下文的时机)。

requests + ThreadPoolExecutor

这里采用的是线程池 + 同步方式,requests 仅支持同步方式:

import time

import requests

from concurrent.futures import ThreadPoolExecutor

numbers = range(12)

url = 'http://httpbin.org/get?a={}'

def fetch(a):

print(a)

r = requests.get(url.format(a))

return r.json()['args']['a']

start = time.time()

# 开三个线程

with ThreadPoolExecutor(max_workers=3) as executor:

for num, result in zip(numbers, executor.map(fetch, numbers)):

print('fetch({})'.format(num, result))

print('使用 requests + ThreadPoolExector 总耗时:{}'.format(time.time() - start)) # 5.696202754974365

asyncio + aiohttp

协程+异步,现在的 asyncio,有了很多的模块已经在支持:aiohttp,aiodns,aioredis 等等 https://github.com/aio-libs:

import asyncio

import time

import aiohttp

url = 'http://httpbin.org/get?a={}'

numbers = range(12)

async def fetch(a):

async with aiohttp.ClientSession() as session:

async with session.get(url.format(a)) as resp:

data = await resp.json()# 等待结果

return data['args']['a']

start = time.time()

event_loop = asyncio.get_event_loop()# 新建事件循环

tasks = [fetch(num) for num in numbers]# 添加到任务列表

# asyncio.gather() 按顺序搜集异步任务执行的结果

results = event_loop.run_until_complete(asyncio.gather(*tasks))# 开启事件循环

for num, result in zip(numbers, resu

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
`asyncio` 和 `Celery` 都是 Python 中用于异步编程的工具,但它们在用途和设计上有所不同。 **asyncio(异步I/O):** - 异步IO库,它是 Python 标准库的一部分,主要侧重于单线程并发处理,适合于 I/O 密集型任务,比如网络请求、文件读写等。通过使用异步/await语法,`asyncio`可以让代码顺序执行,但底层会利用事件循环和回调来管理多个任务并发执行,提高程序响应速度。 - 异步IO适合于对实时性要求较高的场景,例如实时聊天应用或Web服务器。 - asyncio 任务通常是由程序自己启动和管理的。 **Celery:** - 是一个分布式任务队列系统,它基于消息传递模型,能够将耗时的、复杂的、可能需要跨多个机器的任务异步地添加到队列中。Celery 支持多种消息队列如RabbitMQ、Redis等。 - 它的核心是将工作分解为可独立执行的单元,并通过工人(worker)在后台执行这些任务。这使得开发者可以专注于业务逻辑,而无需担心任务调度和失败处理。 - Celery 提供了丰富的错误处理和监控工具,以及跨语言支持,可以与其他语言的消费者进行交互。 - 适用于需要高可用性和可靠性的场景,比如批量数据处理、邮件发送、爬虫等。 **区别总结:** 1. asyncio 主要是针对单机、本地的、轻量级的异步编程,而 Celery 更关注分布式任务的管理和执行。 2. asyncio 更注重单个应用程序内部的并发优化,Celery 则是解决跨进程、跨主机的异步任务分发。 3. 使用 asyncio,程序员需要自行管理任务的调度和错误处理,Celery 提供了更完整的任务管理解决方案。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值