Laravel,Dropzone.js,Apache文件上传超时


Laravel, Dropzone.js, Apache File Upload Timeout

最近,我的系统上的许多用户都遇到了文件上传超时问题。基本上,用户全天登录上传系统,发送通常为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/maxclient增加到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…"answers"未找到控制器方法…"错误。然而,文件上传仍然会随机失败,但现在laravel错误日志中没有报告任何错误。dropzone ajax上传请求只是在一个随机的时间被丢弃,并返回一个状态代码0。

有人知道我下一步该怎么解决这个问题吗?

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