python网络库也有了基于协程的实现,比较著名的是 gevent、eventlet 它两之间的关系可以参照
Comparing gevent to eventlet, 本文主要简单介绍一下eventlet一个例子
客户端:
import eventlet
from eventlet.green import urllib2
def myfetch(myurl, i):
req = urllib2.Request(myurl)
req.add_header('User-agent', 'Mozilla 5.10')
res = urllib2.urlopen(req, timeout = 4)
body = res.read();
size = len(body);
print (i, 'body size ' ,size)
return size
myurl = "http://127.0.0.1:6000"
pool = eventlet.GreenPool(1000)
for i in range(1, 200):
pool.spawn(myfetch, myurl, i)
#print i
pool.waitall()
print "--finish --GreenPool"
服务端:
#! /usr/bin/env python
"""\
Simple server th

本文介绍了Python中两个基于协程的网络库gevent和eventlet,通过一个简单的客户端和服务器例子展示了eventlet的简洁优雅接口。尽管其稳定性和成熟度需要实际场景验证,但eventlet对于快速开发TCP/HTTP服务器,尤其是处理网络IO密集型任务,表现良好。在OpenStack项目中已知有使用eventlet的情况。
最低0.47元/天 解锁文章

被折叠的 条评论
为什么被折叠?



