我想使用 Python 3asyncio
模块来创建服务器应用程序。我使用主事件循环来监听网络,当接收到新数据时,它会进行一些计算并将结果发送给客户端。“做一些计算”是否需要一个新的事件循环?还是可以使用主事件循环?
问问题
10308 次
1 回答
17
您可以在主事件循环中进行计算工作,但是在发生这种情况时整个事件循环将被阻塞 - 无法处理其他请求,并且您在事件循环中运行的任何其他内容都将被阻塞。如果这是不可接受的,您可能希望在单独的进程中运行计算工作,使用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 操作一样等待结果,因此它不会阻止其他协程运行。
于 2014-12-04T16:20:53.073 回答