gpt4 book ai didi

php - Laravel、Dropzone.js、Apache 文件上传超时

转载 作者:行者123 更新时间:2023-11-29 00:08:58 24 4
gpt4 key购买 nike

最近,我的系统上的许多用户都遇到了文件上传超时问题。基本上,用户全天登录到上传系统并发送通常每个 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

我已经以不同的方式更改了这些设置,例如将超时/最大客户端增加到 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 方法...”错误。然而,文件上传仍然随机失败,但现在 laravel 错误日志中没有报告任何错误。 dropzone ajax 上传请求只是在随机时间被丢弃并返回状态代码 0。

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

最佳答案

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

关于php - Laravel、Dropzone.js、Apache 文件上传超时,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26170794/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com