如何在Python中检测ftp服务器超时

将大量文件上载到FTP服务器.在我上传的过程中,服务器超时,阻止我进一步上传.有没有人知道一种方法来检测服务器是否超时,重新连接并继续传输数据?我正在使用Python ftp库进行传输.

谢谢

最佳答案
您可以简单地指定连接的超时,但是对于文件传输或其他操作期间的超时,它不是那么简单.

因为storbinary和retrbinary方法允许您提供回调,所以您可以实现监视程序计时器.每次获得数据时都会重置计时器.如果您至少每30秒(或其他)没有获得数据,监视程序将尝试中止并关闭FTP会话并将事件发送回事件循环(或其他).

ftpc = FTP(myhost,'ftp',30)

def timeout():
  ftpc.abort()  # may not work according to docs
  ftpc.close()
  eventq.put('Abort event')  # or whatever

timerthread = [threading.Timer(30,timeout)]

def callback(data,*args,**kwargs):
  eventq.put(('Got data',data))  # or whatever
  if timerthread[0] is not None:
    timerthread[0].cancel()
  timerthread[0] = threading.Timer(30,timeout)
  timerthread[0].start()

timerthread[0].start()
ftpc.retrbinary('RETR %s' % (somefile,),callback)
timerthread[0].cancel()

如果这还不够好,您似乎必须选择不同的API. Twisted框架有FTP protocol support,允许您添加超时逻辑.

相关文章

在这篇文章中,我们深入学习了XPath作为一种常见的网络爬虫技巧。XPath是一种用于定位和选择XML文档中特...
祝福大家龙年快乐!愿你们的生活像龙一样充满力量和勇气,愿你们在新的一年里,追逐梦想,勇往直前,不...
今天在爬虫实战中,除了正常爬取网页数据外,我们还添加了一个下载功能,主要任务是爬取小说并将其下载...
完美收官,本文是爬虫实战的最后一章了,所以尽管本文着重呈现爬虫实战,但其中有一大部分内容专注于数...
JSON是一种流行的数据传输格式,Python中有多种处理JSON的方式。官方的json库是最常用的,它提供了简单...
独立样本T检验适用于比较两组独立样本的均值差异,而配对T检验则适用于比较同一组样本在不同条件下的均...