所以我在 Pylons 中上传文件时遇到了一个相当棘手的问题,我希望有人能够帮助我。最初我在这里发布了这个问题,认为这是 Pylons 的一个问题,但我已经得出结论,这个问题是由于服务器造成的,即粘贴,我已经准确地追踪了问题发生的位置,但我不确定如何解决它。行为如下。我有一个 Pylons Web 应用程序,我通过 Paster 提供服务。该应用程序的一部分允许用户将文件上传到系统,有时这些文件可能相当大(> 50mb)。在此类上传期间,服务器偶尔会重置连接(即,在 Chrome 中,错误显示为“错误 101 (net::ERR_CONNECTION_RESET):连接已重置。”)这并不总是发生,只有大约 50% 的时间用于较大的文件。
在这些情况下,服务器永远不会将 POST 提交给应用程序级别。没有抛出异常(至少,我能找到)。我已将问题缩小到 cascade.py(特别是从 httpserver.py 调用的 wsgi_application 方法)。从后者:
结果 = self.server.wsgi_application(self.wsgi_environ, self.wsgi_start_response)
在 cascade.py 的调用函数中,该文件似乎被写入了一个临时文件。相关循环开始于:
而copy_len > 0:
然后它将块一一写入打开的文件。这些写入都不会单独引发异常。但是,服务器通常会在这些写入期间简单地“消失”,看似随机(时间似乎也与此无关)。因此,如果我打印出正在减少的 copy_len 大小,我会看到它减少到一个点,然后服务器突然发送一个“连接重置”(或者至少客户端认为它是这样)和方法似乎已退出(copy_len 停止打印,好像循环已退出,尽管它不在 0 处)。
我完全被难住了,因为 1)这只是偶尔发生,并且 2)我似乎无法找到实际的错误/异常——它只是有点……死了。
如果重要的话,我正在运行 paste 1.7.3、Python 2.7 和 Fedora OS。有没有人对可能发生的事情有任何见解,以及我如何能够解决这个问题?非常感谢您的帮助。