我正在使用以下代码顺序下载一些图像,但我得到了很多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