Загрузка файла Python 3.6 ftps - SSLEOFError: EOF произошел с нарушением протокола (_ssl.c:841)
Я пытаюсь написать скрипт, который время от времени отправляется на сервер Filezilla для получения файлов. У меня есть права администратора для сервера и конфигурации Filezilla, но не для всей системы или сети, но запросы могут быть сделаны.
Код:
from ftplib import FTP_TLS
host="11.211.171.41"
ftps = FTP_TLS(host)
ftps.login()
ftps.prot_p()
ftps.dir()
#-r--r--r-- 1 ftp ftp 5636096 Aug 07 00:50 master.mdf
#-r--r--r-- 1 ftp ftp 2097152 Aug 07 00:50 mastlog.ldf
filename = "master.mdf"
with open(filename, 'wb') as f:
ftps.retrbinary('RETR {}'.format(filename), f.write)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "/home/fcontreras/scripts/ftps/ftps.py", line 29, in get
ftps.retrbinary('RETR {}'.format(filename), f.write)
File "/home/fcontreras/miniconda3/envs/ftp/lib/python3.6/ftplib.py", line 442, in retrbinary
with self.transfercmd(cmd, rest) as conn:
File "/home/fcontreras/miniconda3/envs/ftp/lib/python3.6/ftplib.py", line 399, in transfercmd
return self.ntransfercmd(cmd, rest)[0]
File "/home/fcontreras/miniconda3/envs/ftp/lib/python3.6/ftplib.py", line 801, in ntransfercmd
server_hostname=self.host)
File "/home/fcontreras/miniconda3/envs/ftp/lib/python3.6/ssl.py", line 407, in wrap_socket
_context=self, _session=session)
File "/home/fcontreras/miniconda3/envs/ftp/lib/python3.6/ssl.py", line 814, in __init__
self.do_handshake()
File "/home/fcontreras/miniconda3/envs/ftp/lib/python3.6/ssl.py", line 1068, in do_handshake
self._sslobj.do_handshake()
File "/home/fcontreras/miniconda3/envs/ftp/lib/python3.6/ssl.py", line 689, in do_handshake
self._sslobj.do_handshake()
ssl.SSLEOFError: EOF occurred in violation of protocol (_ssl.c:841)
Итак, главное - исправить ошибку, но мне трудно понять, что означает (_ssl.c:841), я не уверен, с чего начать.
1 ответ
Обнаружена проблема, ошибка SSLEOFErr вводит в заблуждение, причина является причиной, потому что базы данных не читаются.
Я не проверял это для начала, потому что разрешения показывались как:
#-r--r--r-- 1 ftp ftp 5636096 Aug 07 00:50 master.mdf
#-r--r--r-- 1 ftp ftp 2097152 Aug 07 00:50 mastlog.ldf
Кажется, что они постоянно открыты ядром базы данных, которое их создало, и окна не позволяют пользователю или FTP-серверу читать файл для передачи.
Надеюсь, это поможет сократить время Google для кого-то.