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

时间:2014-10-02 22:43:02

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

最近,我的系统上的许多用户都遇到了文件上传超时问题。基本上,用户全天都会登录到上传系统,并且每批通常1-10个文件发送通常为1-3MB的文件。当用户上传文件或批处理一段时间后,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

我已经以不同的方式更改了这些设置,例如将超时/ 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 ...”和“Controller method not found ...”错误。但是,文件上载仍然在随机时间失败,但现在laravel错误日志中没有报告错误。 dropzone ajax上传请求在随机时间被删除并返回状态码0.

任何人对我接下来应该尝试解决这个问题有任何想法吗?

1 个答案:

答案 0 :(得分:1)

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