У меня возникла проблема с отладкой моего кода, потому что я не могу понять, что ошибка сокета возникает. Вот трассировка.Соединитель Python ConnectionResetError: [Errno 54] Сброс соединения с помощью peer vs socket.error: [Errno 104] Сброс соединения с помощью peer
Traceback (most recent call last):
File "clickpression.py", line 517, in <module> presser.main()
File "clickpression.py", line 391, in main
File "clickpression.py", line 121, in clickpress self.refresh_proxies(country=country)
File "clickpression.py", line 458, in refresh_proxies self.proxies = self.get_proxies(country=country)
File "helpers.py", line 72, in wrapper return func(*args, **kwargs)
File "clickpression.py", line 264, in get_proxies self.settings.SUPER_PROXY).read().decode('utf-8')
File "/usr/local/Cellar/python3/3.4.3/Frameworks/Python.framework/Versions/3.4/lib/python3.4/urllib/request.py", line 161, in urlopen return opener.open(url, data, timeout)
File "/usr/local/Cellar/python3/3.4.3/Frameworks/Python.framework/Versions/3.4/lib/python3.4/urllib/request.py", line 463, in open response = self._open(req, data)
File "/usr/local/Cellar/python3/3.4.3/Frameworks/Python.framework/Versions/3.4/lib/python3.4/urllib/request.py", line 481, in _open '_open', req)
File "/usr/local/Cellar/python3/3.4.3/Frameworks/Python.framework/Versions/3.4/lib/python3.4/urllib/request.py", line 441, in _call_chain result = func(*args)
File "/usr/local/Cellar/python3/3.4.3/Frameworks/Python.framework/Versions/3.4/lib/python3.4/urllib/request.py", line 1210, in http_open return self.do_open(http.client.HTTPConnection, req)
File "/usr/local/Cellar/python3/3.4.3/Frameworks/Python.framework/Versions/3.4/lib/python3.4/urllib/request.py", line 1185, in do_open r = h.getresponse()
File "/usr/local/Cellar/python3/3.4.3/Frameworks/Python.framework/Versions/3.4/lib/python3.4/http/client.py", line 1171, in getresponse response.begin()
File "/usr/local/Cellar/python3/3.4.3/Frameworks/Python.framework/Versions/3.4/lib/python3.4/http/client.py", line 351, in begin version, status, reason = self._read_status()
File "/usr/local/Cellar/python3/3.4.3/Frameworks/Python.framework/Versions/3.4/lib/python3.4/http/client.py", line 313, in _read_status line = str(self.fp.readline(_MAXLINE + 1), "iso-8859-1")
File "/usr/local/Cellar/python3/3.4.3/Frameworks/Python.framework/Versions/3.4/lib/python3.4/socket.py", line 374, in readinto return self._sock.recv_into(b)
ConnectionResetError: [Errno 54] Connection reset by peer
Согласно errno
библиотеке Errno 54
является errno.EXFULL
, который в Python 3 documentation объясняется как exchange full
.
Насколько я понимаю, Connection reset by peer
является Errno 104
i.e errno.ECONNRESET
.
Так что же означает errno.EXFULL
? и почему сокет вызывает ошибку с описанием connection reset by peer
вместо exchange full
. А также, как связаны две ошибки errno.EXFULL
и errno.ECONNRESET
?
PS: I что errno 54
может быть связано с http proxy (я использую прокси-сервер в своем коде). Если да, то как?
Вы не ответили на мои вопросы – mattgathu
Право - вместо этого я показал способы проверить, являются ли ваши вопросы правильными, поскольку очень сомнительно, имеет ли показанная трассировка какое-либо отношение к EXFULL. – Armali
в моей системе os.strerror (54) возвращает 'Exchange full' и os.strerror (104) - это 'reset connection by peer' – mattgathu