ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

python – 我应该在一个程序中使用两个asyncio事件循环吗?

2019-10-04 19:59:45  阅读:272  来源: 互联网

标签:event-loop python-3-4 python python-asyncio


我想使用Python 3 asyncio模块来创建服务器应用程序.
我使用主事件循环来监听网络,当收到新数据时,它会进行一些计算并将结果发送给客户端. “做一些计算”是否需要新的事件循环?或者它可以使用主事件循环?

解决方法:

您可以在主事件循环中执行计算工作,但在发生这种情况时将阻止整个事件循环 – 不能提供其他请求,并且将阻止您在事件循环中运行的任何其他操作.如果这是不可接受的,您可能希望使用BaseEventLoop.run_in_executor在单独的进程中运行计算工作.这是一个非常简单的示例:

import time
import asyncio
from concurrent.futures import ProcessPoolExecutor

def cpu_bound_worker(x, y):
    print("in worker")
    time.sleep(3)
    return x +y

@asyncio.coroutine
def some_coroutine():
    yield from asyncio.sleep(1)
    print("done with coro")

@asyncio.coroutine
def main():
    loop = asyncio.get_event_loop()
    loop.set_default_executor(ProcessPoolExecutor())
    asyncio.async(some_coroutine())
    out = yield from loop.run_in_executor(None, cpu_bound_worker, 3, 4)
    print("got {}".format(out))

loop = asyncio.get_event_loop()
loop.run_until_complete(main())

输出:

in worker
done with coro
got 7

cpu_bound_worker在子进程中执行,并且事件循环将等待结果,就像任何其他非阻塞I / O操作一样,因此它不会阻止其他协同程序运行.

标签:event-loop,python-3-4,python,python-asyncio
来源: https://codeday.me/bug/20191004/1854144.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有