请求/urllib3下载镜像时重试警告



我正在使用以下代码顺序下载一些图像,但我得到了很多WARNING: Retrying消息。值得注意的是,导致这种情况的图像url每次都在变化,有时根本不会发生。

session = requests.Session()
session.keep_alive = False
adapter = requests.adapters.HTTPAdapter(pool_connections=100, pool_maxsize=100, max_retries=3)
session.mount("http://", adapter)
session.mount("https://", adapter)
response = session.get(image_url, headers=headers, allow_redirects=True, timeout=20)

这会导致警告

2016-06-28 07:16:47 [requests.packages.urllib3.connectionpool] WARNING: Retrying (Retry(total=2, connect=None, read=None, redirect=None)) after connection broken by 'ReadTimeoutError("HTTPConnectionPool(host='s-media-cache-ak0.pinimg.com', port=80): Read timed out. (read timeout=20)",)': /564x/4d/75/78/4d7578cf80d146b9d2b597f8678c7b31.jpg

我如何修复/抑制这些?在我的日志中有很多重试警告是没有意义的。我已经签出了请求的源代码,但我不想禁用所有警告:

log.warning("Retrying (%r) after connection "
            "broken by '%r': %s", retries, err, url)

原来我试图禁用错误的东西。我只是不得不做

import logging
logging.getLogger('requests.packages.urllib3.connectionpool').setLevel(logging.CRITICAL)

禁用urllib3 warnings:

import urllib3
urllib3.disable_warnings()

或者正如urllib3文档建议的那样,您可以使用logging模块捕获警告:

logging.captureWarnings(True)

你也可以在代码外使用PYTHONWARNINGS

最新更新