1

http://eventlet.net/doc/patching.htm中的文档 说“如果没有指定参数,则所有内容都已修补。” 和“线程,它修补线程、线程和队列”。

但是通过一个简单的测试:

#!/bin/env python

import threading

import eventlet
eventlet.monkey_patch()

if __name__ == '__main__':
    patched = eventlet.patcher.is_monkey_patched(threading)
    print('patched : %s' % patched)

结果是:

patched : False

似乎线程根本没有修补。医生有错吗?

4

1 回答 1

1

我发现医生是对的。问题是关于 is_monkey_patched(),它无法检测到诸如“线程,队列”模块之类的情况。看一下这个函数的src,行为很容易理解。

def _green_thread_modules():
    from eventlet.green import Queue
    from eventlet.green import thread
    from eventlet.green import threading
    if six.PY2:
        return [('Queue', Queue), ('thread', thread), ('threading', threading)]
    if six.PY3:
        return [('queue', Queue), ('_thread', thread), ('threading', threading)]

    if on['thread'] and not already_patched.get('thread'):
        modules_to_patch += _green_thread_modules()
        already_patched['thread'] = True

def is_monkey_patched(module):
    """Returns True if the given module is monkeypatched currently, False if
    not.  *module* can be either the module itself or its name.

    Based entirely off the name of the module, so if you import a
    module some other way than with the import keyword (including
    import_patched), this might not be correct about that particular
    module."""
    return module in already_patched or \
        getattr(module, '__name__', None) in already_patched

并且因为补丁操作是这样实现的:

    for name, mod in modules_to_patch:
        orig_mod = sys.modules.get(name)
        if orig_mod is None:
            orig_mod = __import__(name)
        for attr_name in mod.__patched__:
            patched_attr = getattr(mod, attr_name, None)
            if patched_attr is not None:
                setattr(orig_mod, attr_name, patched_attr)

我们可以使用以下方法检查是否对像 threading/Queue 这样的模块进行了修补:

 >>>import threading
 >>>eventlet.monkey_patch()
 >>>threading.current_thread.__module__
 >>>'eventlet.green.threading' 
于 2015-09-09T07:51:00.497 回答