【问题标题】:What is the global default timeout什么是全局默认超时
【发布时间】:2015-06-21 08:26:30
【问题描述】:

Python 3.4 。 尝试在 urllib.request.urlopen() 中查找默认超时时间。

它的签名是: urllib.request.urlopen(url, data=None, [timeout, ]*, cafile=None, capath=None, cadefault=False, context=None)

doc 表示其“全局默认超时”,并查看其代码: socket._GLOBAL_DEFAULT_TIMEOUT

仍然以秒为单位的实际值是多少?

【问题讨论】:

    标签: python request timeout urllib


    【解决方案1】:

    我怀疑这是依赖于实现的。也就是说,对于 CPython:

    来自socket.create_connection

    如果没有提供 timeout,则使用 :func:getdefaulttimeout 返回的全局默认超时设置。

    来自socketmodule.c

    static PyObject *
    socket_getdefaulttimeout(PyObject *self)
    {
        if (defaulttimeout < 0.0) {
            Py_INCREF(Py_None);
            return Py_None;
        }
        else
            return PyFloat_FromDouble(defaulttimeout);
    }
    

    Earlier 在同一个文件中,

    static double defaulttimeout = -1.0; /* Default timeout for new sockets */
    

    所以看起来Py_None,又名None,是默认超时。换句话说,urlopen 永远不会超时。至少不是从 Python 端。如果操作系统提供的网络功能本身超时,我想仍然会发生超时。


    编辑:哎呀,我想我根本不需要去寻找答案,因为它就在docs 中。

    None 的值表示新的套接字对象没有超时。首次导入socket模块时,默认为None

    【讨论】:

    • 所以...它看起来来自 Linux 内核?
    • 当您使用 urllib2.urlopen(link)urllib2.urlopen(link, timeout=1) 时,这会导致一些困难的调试。很高兴我找到了这个答案。
    • @teewuane 不是。无论如何,您通常都会捕获 stderr 进行日志记录。如果您现在意识到您处理空闲,您可以发送一个 SIGINT 并获取最新的跟踪到您的日志:example = request.urlopen([...]) File "/usr/lib/python3.7/urllib/request.py", line 222, in urlopen [...] File "/usr/lib/python3.7/ssl.py", line 1117, in do_handshake self._sslobj.do_handshake() KeyboardInterrupt 但我不认为None 是一个合理的默认超时...
    猜你喜欢
    • 2019-12-04
    • 2018-09-01
    • 2011-01-14
    • 2016-04-16
    • 1970-01-01
    • 2013-01-08
    • 2023-03-19
    • 2010-10-26
    相关资源
    最近更新 更多