【问题标题】:Laravel, Dropzone.js, Apache File Upload TimeoutLaravel、Dropzone.js、Apache 文件上传超时
【发布时间】:2014-11-28 00:44:17
【问题描述】:

最近,我的系统上的许多用户都遇到了文件上传超时问题。基本上,用户全天登录上传系统并发送通常为 1-3MB 的文件,通常为 1-10 个文件。当用户上传文件或批次一定时间时,dropzone 的文件上传失败,并向用户显示消息“服务器以 0 代码响应”。这个问题只是有时会发生,但如果我尝试上传需要几分钟才能上传的大文件,我可以随时轻松地复制问题。到目前为止,我已经搜索并尝试了很多东西,但问题仍然存在。

如果上传成功,则将文件保存到服务器上的某个位置,并将有关每个文件的信息存储在数据库中。

系统使用 Laravel PHP、Dropzone.js、Mysql 和 Apache 构建。下面是一些关于错误日志、配置文件和我尝试过的东西的信息。

这是上传失败后 laravel 错误日志报告的内容:

    [2014-10-02 15:52:26] log.ERROR: exception 'Symfony\Component\HttpKernel\Exception\NotFoundHttpException' in /usr/www/www.example.com/beta/vendor/laravel/framework/src/Illuminate/Routing/Router.php:1429
Stack trace:
#0 /usr/www/www.example.com/beta/vendor/laravel/framework/src/Illuminate/Routing/Router.php(1050): Illuminate\Routing\Router->handleRoutingException(Object(Symfony\Component\Routing\Exception\ResourceNotFoundException))
#1 /usr/www/www.example.com/beta/vendor/laravel/framework/src/Illuminate/Routing/Router.php(1014): Illuminate\Routing\Router->findRoute(Object(Illuminate\Http\Request))
#2 /usr/www/www.example.com/beta/vendor/laravel/framework/src/Illuminate/Foundation/Application.php(576): Illuminate\Routing\Router->dispatch(Object(Illuminate\Http\Request))
#3 /usr/www/www.example.com/beta/vendor/laravel/framework/src/Illuminate/Foundation/Application.php(552): Illuminate\Foundation\Application->dispatch(Object(Illuminate\Http\Request))
#4 /usr/www/www.example.com/beta/public/index.php(49): Illuminate\Foundation\Application->run()
#5 {main} [] []
[2014-10-02 15:52:29] log.ERROR: exception 'Symfony\Component\HttpKernel\Exception\NotFoundHttpException' with message 'Controller method not found.' in /usr/www/www.example.com/beta/vendor/laravel/framework/src/Illuminate/Routing/Controllers/Controller.php:290
Stack trace:
#0 [internal function]: Illuminate\Routing\Controllers\Controller->missingMethod(Array)
#1 /usr/www/www.example.com/beta/vendor/laravel/framework/src/Illuminate/Routing/Controllers/Controller.php(138): call_user_func_array(Array, Array)
#2 /usr/www/www.example.com/beta/vendor/laravel/framework/src/Illuminate/Routing/Controllers/Controller.php(115): Illuminate\Routing\Controllers\Controller->callMethod('missingMethod', Array)
#3 /usr/www/www.example.com/beta/vendor/laravel/framework/src/Illuminate/Routing/Router.php(985): Illuminate\Routing\Controllers\Controller->callAction(Object(Illuminate\Foundation\Application), Object(Illuminate\Routing\Router), 'missingMethod', Array)
#4 [internal function]: Illuminate\Routing\Router->Illuminate\Routing\{closure}(Array)
#5 /usr/www/www.example.com/beta/vendor/laravel/framework/src/Illuminate/Routing/Route.php(80): call_user_func_array(Object(Closure), Array)
#6 /usr/www/www.example.com/beta/vendor/laravel/framework/src/Illuminate/Routing/Route.php(47): Illuminate\Routing\Route->callCallable()
#7 /usr/www/www.example.com/beta/vendor/laravel/framework/src/Illuminate/Routing/Router.php(1016): Illuminate\Routing\Route->run(Object(Illuminate\Http\Request))
#8 /usr/www/www.example.com/beta/vendor/laravel/framework/src/Illuminate/Foundation/Application.php(576): Illuminate\Routing\Router->dispatch(Object(Illuminate\Http\Request))
#9 /usr/www/www.example.com/beta/vendor/laravel/framework/src/Illuminate/Foundation/Application.php(552): Illuminate\Foundation\Application->dispatch(Object(Illuminate\Http\Request))
#10 /usr/www/www.example.com/beta/public/index.php(49): Illuminate\Foundation\Application->run()
#11 {main} [] []

以下是 Apache (httpd.conf) 的一些设置:

KeepAlive On
MaxKeepAliveRequests 500
KeepAliveTimeout 5
ServerLimit 513
MaxClients 100
MaxRequestsPerChild 10000

我以不同的方式更改了这些设置,例如将 timeouts/maxclients 增加到 500,但结果仍然相同。上传在某个时间失败,似乎完全忽略了这些设置。

这是 php.ini 中的一些设置

default_socket_timeout = 500
mysql.connect_timeout = 500
max_execution_time = 1200
max_input_time = 1200
file_uploads = On
max_file_uploads = 50
post_max_size = 2047M
upload_max_filesize = 2047M
memory_limit = 258M

这是 laravel .htaccess 文件

Options -Indexes

我还尝试通过添加“xhr.timeout = 4000”来更改 dropzone.js AJAX 上传代码。通过将此行添加到 dropzone.js,上传将在进度条中部分上传,但它永远不会变红并失败。上传将永远暂停,这让我认为问题出在 laravel 或服务器的某个地方,但我目前不确定。如果没有这些代码,在我看来,AJAX 请求在某个随机时间会被服务器/laravel 丢弃,并且文件上传失败。对我来说更奇怪的是,这个错误最近才开始发生。在此之前的几个月,系统运行平稳并上传文件。

我非常感谢任何关于这个问题的头脑风暴、反馈或帮助。

谢谢

更新:

我将此行添加到我的 filters.php 文件中以查看丢失的路由是什么...

App::missing(function($exception)
{
    Log::error('Missing URL was: ' . Request::fullUrl());
});

我能够从我的 laravel 错误日志中删除所有“NotFoundHTTPException...”和“找不到控制器方法...”错误。但是文件上传还是随机失败,但是现在laravel错误日志中没有报错。 dropzone ajax 上传请求只是在随机时间被丢弃并返回状态码 0。

有人知道我接下来应该尝试什么来解决这个问题吗?

【问题讨论】:

标签: php mysql apache file-upload dropzone.js


【解决方案1】:

错误消失了!我能够将错误追溯到请求不再存在的文件的旧 apache 模块。检查错误日志后,我注意到 Apache 每隔一分钟就会收到一个关闭信号,原因是找不到模块想要的文件。我很高兴现在终于解决了这个问题!

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2019-01-16
    • 1970-01-01
    • 2019-10-10
    • 2018-09-30
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多