nginx は画像表示の遅さとダウンロードの不完全さの問題を解決します

nginx は画像表示の遅さとダウンロードの不完全さの問題を解決します

前面に書かれた

最近、ある読者から、ブラウザからサーバーにアクセスすると、画像の表示が遅く、ブラウザに完全に読み込むことができないという話を聞きました。ファイルをダウンロードするときも、ファイルを完全にダウンロードできないため、さらにイライラしました。そして不思議なことに、このリーダーが接続されているネットワークには問題がありません。そこで私は彼がさまざまな問題を解決するのを手伝い始めました。 。 。

問題の場所

一連の調査(途中の過程は省略して要点だけ直接書きます!)を経て、最終的に問題は Nginx にあることが判明しました。読者のウェブサイトのバックエンド管理システムを開くと、画像の表示が非常に遅く、Nginx フロントエンド プロキシに次のエラー メッセージが表示されていることがわかりました。

[エラー] 28423#0: アップストリームへの接続中に *5 connect() が失敗しました (111: 接続が拒否されました)

バックエンドサーバーの IP アドレスを使用してサービスに直接アクセスしたところ、速度がかなり速かったため、Nginx の設定に問題があるのではないかと疑いました。

注意: 大きな添付ファイルやページ上の大きな画像をダウンロードする場合、ダウンロードが中断されたり、画像が表示できなくなったりします。Nginx のデフォルト設定では、このような問題は一度も発生したことがないと言う人もいるかもしれません。私が言いたいのは、それはあなたのウェブサイトに大きなファイルがなく、少なくとも Nginx のデフォルト設定を使用して読み込むほどの大きさではないからです。

ここでは、以下に示すように、Nginx 構成のセクションを示します。

場所 / ファイル {
	 ルート /home/file;
	 インデックス index.html index.htm;
	 proxy_set_header X-Real-IP $remote_addr;
	 proxy_set_header ホスト $host;
	 プロキシパス http://127.0.0.1:8080 ;
	 クライアントの最大ボディサイズは100mです。
	 クライアントボディバッファサイズ 128k;
	 プロキシ接続タイムアウト 600;
	 プロキシ読み取りタイムアウト 600;
	 プロキシ送信タイムアウト 600;
	 プロキシバッファサイズ 32k;
	 プロキシバッファ 4 64k;
	 proxy_busy_buffers_size 64k;
	 proxy_temp_file_write_size 64k;
}

以下にいくつかの重要なパラメータを示します。

  • proxy_connect_timeout 600; #バックエンド サーバーとの Nginx 接続タイムアウト (プロキシ接続タイムアウト)
  • proxy_read_timeout 600; #接続が成功した後のバックエンドサーバーの応答時間(プロキシ受信タイムアウト)
  • proxy_send_timeout 600; #バックエンドサーバーのデータ返信時間(プロキシ送信タイムアウト)
  • proxy_buffer_size 32k; #ユーザーヘッダー情報を保存するためのプロキシサーバー(nginx)のバッファサイズを設定します
  • proxy_buffers 4 32k; #proxy_buffers バッファ、平均ウェブページサイズが32k以下の場合は、このように設定します
  • proxy_busy_buffers_size 64k; #高負荷時のバッファサイズ (proxy_buffers*2)
  • proxy_temp_file_write_size 16k; #キャッシュフォルダのサイズを設定します。この値より大きい場合、ファイルはアップストリームサーバーから転送されます。

これを見て、問題が分かりました。この読者の Nginx には次の設定行があります。

proxy_temp_file_write_size 16k;

彼のサーバーにある画像は基本的に 100K から 5M の間です。

問題は proxy_temp_file_write_size にあります。サーバー上のファイルがこのパラメータで設定されたサイズを超えると、Nginx はまずファイルを一時ディレクトリ (デフォルトは Nginx インストール ディレクトリの下の /proxy_temp ディレクトリ) に書き込みます。デフォルトでは、Nginx は nobody として起動されます。ls -al コマンドを使用して proxy_temp ディレクトリを表示すると、nobody が proxy_temp ディレクトリの所有者になっています。権限がないのは不思議です。次に、Nginx のインストール ディレクトリである proxy_temp の親ディレクトリを確認します。誰も権限を持っていないことがわかったので、上記の問題が発生したのは不思議ではありません。

問題を解決する

問題が特定されれば、解決しやすくなります。この問題を解決するには、以下に示すように 2 つの方法があります。

  • 誰でも書き込みできるように proxy_temp ディレクトリを設定し、Nginx を再起動すると問題が解決します。
  • proxy_temp_file_write_size の値をイメージとファイルのサイズよりも大きい値に直接変更し、Nginx を再起動します。

最初の方法で問題が解決した場合、たとえば、proxy_temp ディレクトリが /usr/local/nginx/proxy_temp の場合、次のコマンドを使用して、/usr/local/nginx/proxy_temp ディレクトリを誰でも書き込み可能に設定すれば、問題は解決します。

chmod -R 777 /usr/local/nginx/proxy_temp/

2 番目の方法を使用して問題を解決する場合は、次に示すように nginx.conf ファイルを直接変更できます。

場所 / ファイル {
	 ルート /home/file;
	 インデックス index.html index.htm;
	 proxy_set_header X-Real-IP $remote_addr;
	 proxy_set_header ホスト $host;
	 プロキシパス http://127.0.0.1:8080 ;
	 クライアントの最大ボディサイズは100mです。
	 クライアントボディバッファサイズ 256k;
	 プロキシ接続タイムアウト 1200;
	 プロキシ読み取りタイムアウト 1200;
	 プロキシ送信タイムアウト 6000;
	 プロキシバッファサイズ 32k;
	 プロキシバッファ 4 64k;
	 proxy_busy_buffers_size 128k;
	 proxy_temp_file_write_size 10m;
}

もちろん、私はこの読者が他のいくつかの構成項目を最適化するのにも協力しました。

さて、今日はここまでにしましょう!より多くの人が見て、一緒に学び、向上できるように、「いいね!」、フォロー、転送することを忘れないでください。 !

上記は、nginx が画像表示の遅さとダウンロードの不完全さの問題を解決する方法の詳細です。nginx が画像表示の遅さとダウンロードの不完全さの問題を解決する方法の詳細については、123WORDPRESS.COM の他の関連記事に注目してください。

以下もご興味があるかもしれません:
  • Nginx+FastDFSでイメージサーバーを構築
  • Docker で Nginx イメージ サーバーを構築する方法
  • Nginx プロキシを使用して拡大縮小された画像を出力する方法
  • CentOS サーバーで nginx イメージ ホットリンク保護を設定する方法
  • 画像パスにアクセスして HTML 静的ページを取得するように nginx を構成する方法
  • Linux環境でnginxを使ってシンプルな画像サーバーを構築する
  • Nginx イメージホットリンク保護設定例

<<:  シンプルなショッピングカートの最も完全なコード分析を実装する JavaScript (ES6 オブジェクト指向)

>>:  MySQLがウィンドウ関数で合計関数を実行するときに発生する可能性のあるバグ

推薦する

Vue ElementUI で Excel ファイルを手動でサーバーにアップロードする方法の詳細な説明

目次概要プロパティ設定処理ロジック概要具体的な需要シナリオは次のとおりです。 Excel ファイルを...

MySQL の frm ファイルからテーブル構造を復元する 3 つの方法 [推奨]

mysql が正常に実行されている場合、テーブル構造を表示することは難しくありません。しかし、場合...

Bツリー挿入プロセスの概要

前回の記事 https://www.jb51.net/article/154153.htm では、B...

Linux の Docker コンテナで bash を終了する 2 つの方法

bash を終了する場合は、次の 2 つのオプションがあります。最初のもの: Ctrl + d を押...

MySQLはデータテーブル内の既存のテーブルを分割します

目次操作方法操作プロセス既存のテーブルにパーティション テーブルを作成し、データを新しいテーブルに移...

vue3.0 のウォッチ リスナーの例の詳細な説明

目次序文リスナーと計算プロパティの違いvue3 で watch を使用するにはどうすればいいですか?...

Linux に JDK1.8 をインストールするための詳細なチュートリアル

1. 設置前の清掃 rpm -qa | grep jdk rpm -qa | grep gcj yu...

Nexus を使用して jar パッケージをプライベート サーバーに追加する方法

なぜ Nexus プライベート サーバーを構築する必要があるのでしょうか。その理由は非常に簡単です。...

Tomcat の設定と Eclipse での起動方法

目次Tomcat8のインストールと設定方法tomcat ダウンロードTomcat マネージャーを有効...

Linux dirnameコマンドの具体的な使い方

01. コマンドの概要dirname - ファイル名からディレクトリ以外のサフィックスを削除しますd...

Vueでブラウザ共有機能を呼び出す方法

序文Vue(発音は /vjuː/、view に似ています)は、ユーザーインターフェイスを構築するため...

MySQLの7種類のログの概要

MySQL には次のログ ファイルがあります。 1: 再実行ログ2: ロールバックログ(元に戻すログ...

Linux アカウントのパスワードを変更する詳細な例

個人アカウントのパスワードを変更する一般ユーザーが個人アカウントのパスワードを変更する場合は、他のコ...

Linux で文字列を整理するためのヒント

Linuxの操作では、ファイル内の文字列を置換したりカウントしたりすることが多いです。ここでまとめを...

Mysql マスタースレーブ同期 Last_IO_Errno:1236 エラー解決

Mysql マスタースレーブ同期の Last_IO_Errno:1236 エラーの原因は何ですか? ...