协程并发框架gevent及其用法

时间:2024-08-17 17:06:38

gevent是python的一个并发框架,采用协程实现并发目的,用起来也非常简单

gevent的docs:http://www.gevent.org/contents.html

一个最简单的例子:

import gevent

import gevent.monkey
gevent.monkey.patch_all() def foo(i, a, b, c):
print('Running in foo' + str(i) + ' ' + str(a) + str(b) + str(c))
gevent.sleep(0)
print('Explicit context switch to foo again') tasks = [ gevent.spawn(foo,i, 1, 2,3) for i in range(0,10)]
gevent.joinall(tasks)

其中,

gevent.monkey.patch_all()的作用是将一些常见的阻塞,如socket、select等会阻塞的地方实现协程跳转,而不是在那里一直等待,导致整个协程组无法工作。