nginxで大きなファイルをダウンロードする際のファイル破損とファイルサイズの不一致の問題を解決する
今日、友人が問題を報告しました。Web ページに 2MB のファイルがアップロードされたが、そのファイルは 64KB しかなく、開けなかったそうです。バグが存在し、必ず出現することを確認した後、私はデバッグとバグ解決の道を歩み始めました。
1. システムは nginx+php+mysql です。経験から判断すると、mysql とは関係がないため、無視して構いません。
2. PHP Web ページから 2MB のファイルをアップロードした後、ファイルをサーバー上で直接開きます。ファイルは通常どおり表示でき、元のファイルと同じバイナリです。
3. 別のブラウザと別のコンピュータを使用して、PHP Web ページからファイルを繰り返しダウンロードすると、ダウンロードされたファイルがわずか 64 KB であることがわかります。
4. 90KBのみのファイルに変更し、PHPのWebページからアップロード、ダウンロードしても異常はありません。
上記の 4 点により、基本的に nginx に問題があると判断できます。この時点で、nginx ログ ファイルを開き、次のエラー ログを見つけます。
[crit] 21636#0: *843968 open() “/home/www/local/nginx/fastcgi_temp/0/11/0000000110” がアップストリームの読み取り中に失敗しました (13: 許可が拒否されました)。
fastcgi_temp フォルダを操作するための権限が不足しているため、正常なファイルが取得できないため、フォルダに権限を付与すると問題は解決すると推測できます。
fastcgi_connect_timeout 300;
fastcgi_send_timeout 300;
fastcgi_read_timeout 300;
**fastcgi_buffer_size 64k;
fastcgi_buffers 4 64k;**
fastcgi_busy_buffers_size 128k;
fastcgi_temp_file_write_size 128k;
ダウンロードが失敗するたびに、ファイル サイズは常に 64 KB になりますが、これはこれに関連しているはずです。 nginx は、fastcgi_buffer_size で指定されたサイズのバッファを使用して、fastcgi ストリームのコンテンツをキャッシュすることがわかります。サイズがこのサイズを超えると、fastcgi_buffers で指定された数とサイズのバッファーが引き続き適用されます。それでもこのサイズを超える場合は、超過したコンテンツが一時ファイルに書き込まれます。つまり、この場合、nginx はまず 64K バッファを使用して fastcgi ストリームの最初の部分をバッファリングし、その後、バッファリングのために最大 4*64K=256K バッファを適用します。それを超えると、一時ファイルが書き込まれます。したがって、256K を超えるファイルをダウンロードする場合は、一時フォルダーをバッファリングに使用する必要があり、ここでの操作権限がないため、この問題が発生します。
').addClass('事前番号付け').hide();
$(this).addClass('has-numbering').parent().append($numbering);
for (i = 1; i
').text(i));
};
$numbering.fadeIn(1700);
});
});
上記では、nginx で大きなファイルをダウンロードする際のファイル破損とファイル サイズの不一致に対する解決策を、問題の側面も含めて紹介しました。PHP チュートリアルに興味のある友人に役立つことを願っています。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











Tomcat サーバーが外部ネットワークにアクセスできるようにするには、以下を行う必要があります。 外部接続を許可するように Tomcat 構成ファイルを変更します。 Tomcat サーバー ポートへのアクセスを許可するファイアウォール ルールを追加します。 Tomcat サーバーのパブリック IP を指すドメイン名を指す DNS レコードを作成します。オプション: リバース プロキシを使用して、セキュリティとパフォーマンスを向上させます。オプション: セキュリティを強化するために HTTPS を設定します。

Nginx の開始コマンドと停止コマンドは、それぞれ nginx と nginx -s quit です。 start コマンドはサーバーを直接起動し、stop コマンドはサーバーを正常にシャットダウンして、現在のすべてのリクエストを処理できるようにします。その他の使用可能な停止信号には、停止およびリロードがあります。

ThinkPHP フレームワークをローカルで実行する手順: ThinkPHP フレームワークをローカル ディレクトリにダウンロードして解凍します。 ThinkPHP ルート ディレクトリを指す仮想ホスト (オプション) を作成します。データベース接続パラメータを構成します。 Webサーバーを起動します。 ThinkPHP アプリケーションを初期化します。 ThinkPHP アプリケーションの URL にアクセスして実行します。

phpMyAdmin に登録するには、まず MySQL ユーザーを作成して権限を付与し、次に phpMyAdmin をダウンロード、インストール、構成し、最後に phpMyAdmin にログインしてデータベースを管理する必要があります。

Node.js プロジェクトのサーバー デプロイメント手順: デプロイメント環境を準備します。サーバー アクセスの取得、Node.js のインストール、Git リポジトリのセットアップ。アプリケーションをビルドする: npm run build を使用して、デプロイ可能なコードと依存関係を生成します。コードをサーバーにアップロードします: Git またはファイル転送プロトコル経由。依存関係をインストールする: サーバーに SSH で接続し、npm install を使用してアプリケーションの依存関係をインストールします。アプリケーションを開始します。node Index.js などのコマンドを使用してアプリケーションを開始するか、pm2 などのプロセス マネージャーを使用します。リバース プロキシの構成 (オプション): Nginx や Apache などのリバース プロキシを使用して、トラフィックをアプリケーションにルーティングします。

「nginx へようこそ!」エラーを解決するには、仮想ホスト構成を確認し、仮想ホストを有効にし、Nginx をリロードする必要があります。仮想ホスト構成ファイルが見つからない場合は、デフォルト ページを作成して Nginx をリロードすると、エラー メッセージが表示されます。が消え、ウェブサイトは通常のショーになります。

Web サイトにアクセスすると nginx が表示されます。その理由としては、サーバーのメンテナンス、サーバーのビジー状態、ブラウザーのキャッシュ、DNS の問題、ファイアウォールのブロック、Web サイトの構成ミス、ネットワーク接続の問題、Web サイトのダウンなどが考えられます。次の解決策を試してください: メンテナンスが終了するまで待つ、オフピーク時間にアクセスする、ブラウザのキャッシュをクリアする、DNS キャッシュをフラッシュする、ファイアウォールまたはウイルス対策ソフトウェアを無効にする、サイト管理者に連絡する、ネットワーク接続を確認する、または検索エンジンを使用するWeb アーカイブを使用して、サイトの別のコピーを見つけます。問題が解決しない場合は、サイト管理者にお問い合わせください。

Docker 環境でのコンテナ通信には、共有ネットワーク、Docker Compose、ネットワーク プロキシ、共有ボリューム、メッセージ キューの 5 つの方法があります。分離とセキュリティのニーズに応じて、Docker Compose を利用して接続を簡素化するか、ネットワーク プロキシを使用して分離を強化するなど、最も適切な通信方法を選択します。
