Загрузка файла 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 для кого-то.

Другие вопросы по тегам