質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
Apache

Apacheは、Apache HTTP Serverの略で、最も人気の高いWebサーバソフトウェアの一つです。安定性が高いオープンソースソフトウェアとして商用サイトから自宅サーバまで、多くのプラットフォーム向けに開発・配布されています。サーバーソフトウェアの不具合(NCSA httpd)を修正するパッチ(a patch)を集積、一つ独立したソフトウェアとして開発されました。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

CakePHP

CakePHPは、PHPで書かれたWebアプリケーション開発用のフレームワークです。 Ruby on Railsの考え方を多く取り入れており、Railsの高速性とPHPの機動性を兼ね備えています。 MVCやORMなどを「規約優先の考え方」で利用するため、コードを書く手間を省くことができます。 外部のライブラリに依存しないので、単体での利用が可能です。

Q&A

解決済

5回答

2293閲覧

【PHP】アップロードファイルの最大容量の上限を上げたが、大容量のファイルをアップロードするとエラーが発生

sawamu

総合スコア11

Apache

Apacheは、Apache HTTP Serverの略で、最も人気の高いWebサーバソフトウェアの一つです。安定性が高いオープンソースソフトウェアとして商用サイトから自宅サーバまで、多くのプラットフォーム向けに開発・配布されています。サーバーソフトウェアの不具合(NCSA httpd)を修正するパッチ(a patch)を集積、一つ独立したソフトウェアとして開発されました。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

CakePHP

CakePHPは、PHPで書かれたWebアプリケーション開発用のフレームワークです。 Ruby on Railsの考え方を多く取り入れており、Railsの高速性とPHPの機動性を兼ね備えています。 MVCやORMなどを「規約優先の考え方」で利用するため、コードを書く手間を省くことができます。 外部のライブラリに依存しないので、単体での利用が可能です。

0グッド

3クリップ

投稿2019/07/08 06:31

編集2019/07/08 09:32

前提・実現したいこと

PHP(CakePHP)でシステムを構築しています。
動画アップロード機能を実装したのですが、200MB以上の動画をアップロードするとエラーが発生します。

発生している問題・エラーメッセージ

このサイトにアクセスできません 接続がリセットされました。 次をお試しください 接続を確認する プロキシとファイアウォールを確認する ERR_CONNECTION_RESET

GoogleChromeの上記のエラーメッセージが表示されます。

該当のソースコード・試したこと

.htaccessを変更すれば解決できると考え、上限を上げるコードを記述しました。

php

1# Uncomment the following to prevent the httpoxy vulnerability 2# See: https://httpoxy.org/ 3#<IfModule mod_headers.c> 4# RequestHeader unset Proxy 5#</IfModule> 6 7<IfModule mod_rewrite.c> 8 RewriteEngine on 9 RewriteCond %{HTTPS} off 10 RewriteRule ^(.*)$ https://%{HTTP_HOST}%{REQUEST_URI} [R,L] 11 RewriteRule ^$ webroot/ [L] 12 RewriteRule (.*) webroot/$1 [L] 13</IfModule> 14 15#メモリ使用量の上限 16php_value memory_limit 500M 17 18#POSTデータの最大サイズ ※合計サイズ 19php_value post_max_size 500M 20 21#1ファイルあたりの最大アップロードサイズ 22php_value upload_max_filesize 500M

phpinfo()で.htaccessのコードが反映されているか確認したところ反映されていました。

DirectiveLocal ValueMaster Value
memory_limit500M128M
post_max_size500M8M
upload_max_filesize500M2M

反映されいたのですが、相変わらず200MB以上の動画をアップロードするとエラーがでます。

  • AppController.phpにexitを記述したが、コントローラに到達する前にエラーが出ている
  • 199MB以下の動画なら正常にアップロードできる
  • ブラズザをChrome(シークレットモード)、Safari、Firefoxでも試したがダメ
  • ApacheやCakePHPのエラーログには、原因となりそうなものは見つからない
  • 検証で199MB以下の動画をアップロードしたが、コントローラ側でデバックした際に意図していないデータは飛んできていない
  • テンポラリディレクトリの容量の確認し、空き容量があり問題なし
  • アンチウィルスソフトを無効にし、検証したがダメ
  • 他のサーバで検証で素のPHPでformを飛ばしたところ、同じエラーに遭遇
  • max_execution_timeを180に設定したが、30秒も経たずにエラー
  • php.iniにmemory_limit = 500M / post_max_size = 500M /upload_max_filesize = 500Mを記述したがダメ

原因がわかりそうな方、アドバイスをいただけると幸いです。

補足情報(FW/ツールのバージョンなど)

  • PHP Version 5.6.40
  • Apache/2.4.39
  • CAKE_VERSION 3.4.14
  • LAMP環境

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

m.ts10806

2019/07/08 06:33

>200MB以上の動画 実際はどれくらいのサイズなのでしょうか。 またファイル以外は送信していませんか?
sawamu

2019/07/08 06:38

ご返信ありがとうございます。動画は201MBの動画です。debugでコントローラで送られきたpostの中身を確認しましたが、意図していないデータは飛んできていませんでした。
hentaiman

2019/07/08 06:38

そういう時はさらに極端な容量(1Gとか)に変えて試してみると、容量設定が原因なのかそれ以外が原因なのかを判断しやすくなりますぞ あとはエラーログ見ましょう
m.ts10806

2019/07/08 06:42

ん?upload_maxなりpost_max超えるとPHP側はエラー吐くかNULLになったはずですけど、デバッグ確認できるということはphp本体の設定の問題ではなさそうに思います。
sawamu

2019/07/08 06:46

hentaimanさん、ありがとうございます。 容量を大きくして試してApacheとCakePHPのエラーログを改めて確認してみます。
sawamu

2019/07/08 06:49

説明不足でした。200MB以上の動画の場合は、コントローラに到達する前にブラウザのエラーが出るため、検証の際は199MB以下の動画で試しました。
m.ts10806

2019/07/08 06:51

あ、了解です。 それも「試したこと」になるので追記しておいてもらえますか?
sawamu

2019/07/08 06:52

承知しました!
sawamu

2019/07/08 07:42 編集

試しに3.62GBのファイルをアップロードを試みて、Apacheのerror.logを確認しました。下記のエラーが出ていました。 ``` [:error] [pid 29410] [client 124.57.275.85:63189] PHP Warning: POST Content-Length of 3620683885 bytes exceeds the limit of 524288000 bytes in Unknown on line 0, referer: https://demo.test.jp/index.php ``` 「500MBの設定だから大きすぎるよ」という意味ですかね。 CakePHPに特にerror.logは吐かれていませんでした。
m.ts10806

2019/07/08 07:47

500MB設定は生きていますね。 やはり、CakePHP側の設定が関係してそうに思います。
sawamu

2019/07/08 07:59

別のサーバで素のPHPでリクエストを飛ばしたところ、同じエラーがでました。もしかしたら、AWSやApacheの設定の影響しているかもしないと考えています。平行してCakePHP側も調査します。
退会済みユーザー

退会済みユーザー

2019/07/08 08:49

php処理の実行時間 max_execution_time ってのもあるので、伝送処理とその後のサーバー内の処理時間が極端に短すぎて影響出ていないかも、ちょっと気になる。
sawamu

2019/07/08 08:57

ありがとうございます。max_execution_timemも180などで設定して試したのですが、30秒も経たずにエラーを吐きます。
退会済みユーザー

退会済みユーザー

2019/07/08 10:16 編集

じゃぁやはり書き込めるディスク領域が足りない(全体で空きがあっても、quotaが設定されているとか)線が濃厚でしょうか。OS固有部分と、Apache固有の部分の総点検を。
sawamu

2019/07/08 10:55

ありがとうございます。その辺りで原因を探ってみます。
guest

回答5

0

httpd.confにRequestReadTimeout header=20-40,MinRate=500 body=20,MinRate=500を記述して解決

<手順>

  1. httpd.confにタイムアウトを伸ばすコードを記述 RequestReadTimeout header=20-40,MinRate=500 body=20,MinRate=500
  2. Apacheを再起動 $ sudo service httpd restart

■/etc/httpd/conf/httpd.conf

# # EnableMMAP and EnableSendfile: On systems that support it, # memory-mapping or the sendfile syscall may be used to deliver # files. This usually improves server performance, but must # be turned off when serving from networked-mounted # filesystems or if support for these functions is otherwise # broken on your system. # Defaults if commented: EnableMMAP On, EnableSendfile Off # #EnableMMAP off EnableSendfile on # Supplemental configuration # # Load config files in the "/etc/httpd/conf.d" directory, if any. IncludeOptional conf.d/*.conf RequestReadTimeout header=20-40,MinRate=500 body=20,MinRate=500

参考記事

投稿2019/07/09 08:36

sawamu

総合スコア11

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2019/07/09 08:54

apache の log に残っても良さそうですけどねぇ^^; log level が足りなかったのかなぁ。。。 ともあれ、お疲れ様でした!
sawamu

2019/07/09 08:55

私が確認した範囲では、Apacheのエラーで確認できませんでした。te2jiさん、いろいろとアドバイスいただきましてありがとうございました!
guest

0

自己解決

httpd.confにRequestReadTimeout header=20-40,MinRate=500 body=20,MinRate=500を記述して解決

<手順>

  1. httpd.confにタイムアウトを伸ばすコードを記述 RequestReadTimeout header=20-40,MinRate=500 body=20,MinRate=500
  2. Apacheを再起動 $ sudo service httpd restart

■/etc/httpd/conf/httpd.conf

# # EnableMMAP and EnableSendfile: On systems that support it, # memory-mapping or the sendfile syscall may be used to deliver # files. This usually improves server performance, but must # be turned off when serving from networked-mounted # filesystems or if support for these functions is otherwise # broken on your system. # Defaults if commented: EnableMMAP On, EnableSendfile Off # #EnableMMAP off EnableSendfile on # Supplemental configuration # # Load config files in the "/etc/httpd/conf.d" directory, if any. IncludeOptional conf.d/*.conf RequestReadTimeout header=20-40,MinRate=500 body=20,MinRate=500

参考記事

投稿2019/07/09 08:35

sawamu

総合スコア11

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

apacheのLimitRequestBodyも確認したほうがよいでしょう

apache

1<Files *.php> 2LimitRequestBody 0 3</Files>

みたいな感じです

投稿2019/07/08 07:10

yambejp

総合スコア114581

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

sawamu

2019/07/08 09:28

ご回答ありがとうございます。 httpd.confの<Directory "/var/www/html"></Directory>の中にLimitRequestBody 0を記載して、Apacheの再起動をしましたが解消されませんでした。
guest

0

200M っていう中途半端な数字(人間のわかりやすい数字)と、ERR_CONNECTION_RESETから想像すると、経路の途中で切られている気がします。

経路上の アンチウィルスソフトとか、WAF/IPS/FW/PROXY は確認できますか?

投稿2019/07/08 07:10

退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

sawamu

2019/07/08 08:56

ありがとうございます。 アンチウィルスソフトはオフにして試したり、Chromeのシークレットモードや他のブラウザでも試しましたが解消されませんでした。 「WAF」「IPS」「FW」「PROXY」と「ERR_CONNECTION_RESET」で検索(例 WAF ERR_CONNECTION_RESET)したのですが良さそうな記事が見当たりませんでした。おすすめの記事や、WAF/IPS/FW/PROXYの具体的な確認すべきコードの部分等はありますでしょうか?
退会済みユーザー

退会済みユーザー

2019/07/08 09:12 編集

うーん。どうも私が勘違いしているようです。申し訳ない。 https://stackoverflow.com/questions/25378703/err-connection-reset-with-php-script > ERR_CONNECTION_RESET usually means that the connection to the server has died without any responses to the client – not even some kind of HTTP 5xx error. This means that the entire PHP process has died without being able to shut down properly. This is usually not caused by something like an exceeded memory_limit, because that's something PHP would handle gracefully. This must be some sort of Segmentation Fault or similar. If you have access to error logs, check them. Otherwise, you might get support from your hosting company. とあるので、サーバもしくはクライアントで問題が発生していますね。。。 経路を疑った本回答は外れです。
sawamu

2019/07/08 09:13

お調べいただきありがとうございます!添付していただいた記事を読ませていただきます。
guest

0

外していたらすみません、私も似たような現象でハマったことがあるのでご参考まで。

PHPの制限というより、アップロードされたファイルが入るテンポラリディレクトリはどこか正確に把握されてはどうでしょうか。場所によっては容量が制限されていたりしますし、テンポラリにゴミが残っていて、容量を圧迫していることもあります。
テンポラリの容量不足でサーバプログラム側でファイルを取り出せないため、見た目にはアップロードが失敗しているように見える場合があります。

投稿2019/07/08 06:50

編集2019/07/08 06:52
KoichiSugiyama

総合スコア3041

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

sawamu

2019/07/08 06:58

ご回答ありがとうございます。確認いたします。
sawamu

2019/07/08 08:08 編集

テンポラリディレクトリの容量には余裕がありました。 <確認方法> ・ターミルで接続 ・$ sudo df -h 結果↓ devtmpfs 483M 60K 483M 1% /dev tmpfs 493M 0 493M 0% /dev/shm /dev/xvda1 99G 77G 23G 78% /
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問