关于gevent的Timeout(超时)问题……

真的是内牛满面啊,虽然4个月前就开始用gevent,但是直到今天才知道到底怎么才能设置gevent(含monkey打patch后)的超时!!

官方文档太坑爹了,在很隐藏的一个角落里才发现这么一个类gevent.Timeout。

事情是这样的:我们常用的socket都是阻塞的,那么超时是很好设置的。但是,用过Linux下非阻塞I/O的都知道,非阻塞情况下,设置连接超时神马都是浮云的,因为人家是非阻塞的……

于是,当我们用monkey.patch_all()之后,所有的socket都会被转化位非阻塞的,于是在urllib2.open(xx,timeout=yy)这里yy就无效了!

怎么办?用gevent其实提供了这个Timeout类,当你的类似sleep(由于I/O、sleep等原因挂起)超时超过了Timeout的时间限制后,会自动终止block,跳出。

怎么模拟一个超时事件呢,很简单,我们在monkey打了patch后,非翻墙get一把访问twitter,默认情况,会很长时间才返回的哦!

import gevent
import gevent.monkey
import urllib

gevent.monkey.patch_all()

def test():
    #就这么用,7是超时时间,后面的False表示不抛出其他异常了!
    with gevent.Timeout(7, False) as timeout:
        urllib.urlopen("http://www.twitter.com")

if __name__ == "__main__":
    g = gevent.spawn(test)
    g.join()

然后,一旦到了7秒,我们的程序就会乖乖的自动返回啦!

这个夜真没白熬……

5 thoughts on “关于gevent的Timeout(超时)问题……

  1. tt

    我想请教关于gevent的东西,我也是刚刚学习使用这个东西,能给一个方便的联系方式么。求指导

    Reply
  2. young001

    事情是这样的:我们常用的socket都是非阻塞的,那么超时是很好设置的。 应该是说“我们常用的socket都是阻塞的,那么超时是很好设置的。” 多了个非字吧

    Reply

Leave a Reply

Your email address will not be published. Required fields are marked *