之前写过一篇通过队列、池来持续追加任务的方式:[url]http://iyuan.iteye.com/blog/781168[/url]
今个儿重新咀嚼了下,发现gevent的pool似乎可以达到真正意义上的任务追加。
这里先重新简单的阐明下“任务”这个概念,相对于上次那篇,相对宏观了些:
就是Greenlet!(不熟悉的可以参看下gevent的文档[url]http://www.gevent.org/contents.html[/url])
先实例化:
g = pool.Pool()
通过g.add(),g.spawn(),就可以持续追加任务入池,在建立pool时,可以设置size,不过这里似乎有个bug,设定了size后,似乎不能在子任务中再添加新任务进任务表。
下面给个demo:
相较于上次那篇,可以做更繁复的事了,不过,根本上而言,一次做一件事 才是王道啊。
今个儿重新咀嚼了下,发现gevent的pool似乎可以达到真正意义上的任务追加。
这里先重新简单的阐明下“任务”这个概念,相对于上次那篇,相对宏观了些:
就是Greenlet!(不熟悉的可以参看下gevent的文档[url]http://www.gevent.org/contents.html[/url])
先实例化:
g = pool.Pool()
通过g.add(),g.spawn(),就可以持续追加任务入池,在建立pool时,可以设置size,不过这里似乎有个bug,设定了size后,似乎不能在子任务中再添加新任务进任务表。
下面给个demo:
from gevent import pool
g = pool.Pool()
def a():
for i in xrange(100):
g.spawn(b)
def b():
print 'b'
g.spawn(a)
g.join()
相较于上次那篇,可以做更繁复的事了,不过,根本上而言,一次做一件事 才是王道啊。