nginx を最適化する 6 つの方法

nginx を最適化する 6 つの方法

1. Nginxの同時実行性を最適化する

[root@proxy ~]# ab -n 2000 -c 2000 http://192.168.4.5/
192.168.4.5 のベンチマーク (しばらくお待ちください)
ソケット: 開いているファイルが多すぎます (24) //開いているファイルが多すぎることを示すプロンプト

同時実行性を高めるためにNginx設定ファイルを変更する

[root@proxy ~]# vim /usr/local/nginx/conf/nginx.conf
.. ..
worker_processes 2; //CPUコア数と同じ events {
worker_connections 65535; //ワーカーあたりの同時接続の最大数は epoll を使用します。
}
.. ..
[root@proxy ~]# nginx -s reload

2. Linuxカーネルパラメータを最適化する(ファイルの最大数)

[root@proxy ~]# ulimit -a //すべての属性値を表示 [root@proxy ~]# ulimit -Hn 100000 //ハード制限を設定(一時ルール)
[root@proxy ~]# ulimit -Sn 100000 //ソフト制限を設定する(一時的なルール)
[root@proxy ~]# vim /etc/security/limits.conf
 .. ..
* ソフトノーファイル 100000
* ハードノーファイル 100000
#設定ファイルは次のように 4 つの列に分かれています。
#ユーザーまたはグループのハード制限またはソフト制限 制限する必要があるアイテム制限の値

最適化後のサーバーの同時実行性をテストする

[root@proxy ~]# ab -n 2000 -c 2000 http://192.168.4.5/

3. Nginxパケットヘッダーキャッシュを最適化する

[root@proxy ~]# cat lnmp_soft/buffer.sh 
#!/bin/bash
URL=http://192.168.4.5/index.html?
i が {1..5000} の範囲にある場合
する
 URL=${URL}v$i=$i
終わり
curl $URL // 5000サイクル後、長いURLアドレスバーが生成されます [root@proxy ~]# ./buffer.sh
.. ..
<center><h1>414 Request-URI Too Large</h1></center> //ヘッダー情報が大きすぎることを通知する

Nginx 設定ファイルを変更してパケット ヘッダー キャッシュ サイズを増やす

[root@proxy ~]# vim /usr/local/nginx/conf/nginx.conf
.. ..
http {
client_header_buffer_size 1k; // デフォルトのリクエスト ヘッダー情報キャッシュ large_client_header_buffers 4 4k; // 大きなリクエスト ヘッダー情報のキャッシュの数と容量。
}
[root@proxy ~]# nginx -s reload

4. ページを圧縮する

[root@proxy ~]# cat /usr/local/nginx/conf/nginx.conf
http {
.. ..
gzip on; // 圧縮をオンにします gzip_min_length 1000; // 小さなファイルは圧縮されません gzip_comp_level 4; // 圧縮率 gzip_types text/plain text/css application/json application/x-javascript text/xml application/xml application/xml+rss text/javascript;
         //特定のファイルを圧縮します。タイプについては mime.types を参照してください。
.. ..

5. サーバーメモリキャッシュ

http { 
open_file_cache 最大=2000 非アクティブ=20秒;
  open_file_cache_valid 60秒;
  オープンファイルキャッシュの最小使用数は 5 です。
  open_file_cache_errors をオフ;
// サーバーが最大 2000 個のファイル ハンドルをキャッシュするように設定し、20 秒以内に要求のないファイル ハンドルを閉じます。// ファイル ハンドルの有効期間は 60 秒で、60 秒後に期限切れになります。// 5 回以上アクセスされたファイルのみがキャッシュされます。}

6. ブラウザのローカルキャッシュの静的データ

[root@proxy ~]# vim /usr/local/nginx/conf/nginx.conf
サーバー{
  聞く 80;
  server_name ローカルホスト;
  位置 / {
   ルートhtml;
   インデックス index.html index.htm;
  }
場所 ~* \.(jpg|jpeg|gif|png|css|js|ico|xml)$ {
expires 30d; //クライアントのキャッシュ時間を30日間に定義します}
}
[root@proxy ~]# cp /usr/share/backgrounds/day.jpg /usr/local/nginx/html
[root@proxy ~]# nginx -s reload 

これで、nginx 最適化の 6 つの方法についての記事は終了です。より関連性の高い nginx 最適化コンテンツについては、123WORDPRESS.COM の以前の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • nginx 基本チュートリアル
  • Nginx 設定入門チュートリアル
  • Windows での nginx HTTP サーバーの入門チュートリアル
  • Nginx ロードバランシングとは何か、そしてそれをどのように設定するか
  • Nginx 最適化サービスで Web ページ圧縮を実装する方法
  • Nginx がフロントエンド リソースへのクロスドメイン アクセスの問題をどのように解決するかの詳細な説明
  • proxy_pass を設定した後に Nginx が 404 を返す問題を解決する
  • Nginx をベースに特定の IP への短期アクセス数を制限する
  • Nginx の構成と HTTP 実装コード分析との互換性
  • Nginx サービス クイック スタート チュートリアル

<<:  Robots.txtの詳細な紹介

>>:  CSS の両端揃えを実現する div+css レイアウトの 4 つの方法の概要

推薦する

CSS は、モバイル端末でクリックされたときに生成された要素の背景色を削除します (推奨)

クリック時に背景色を生成する要素の CSS スタイルに次のコードを追加します。 -webkit-ta...

MySQL 面接の質問: ハッシュ インデックスの設定方法

B-Tree インデックスに加えて、MySQL は次のインデックスも提供します。ハッシュインデックス...

Tomcat のメモリ構成の正しい姿勢についての簡単な説明

1. 背景多くのブログや記事を読みましたが、JVM のメモリ割り当て方法に関する包括的な記事は見つか...

カスタムスクロールバー効果を実現するJavaScript

実際のプロジェクトでは、上下のスクロール バーと左右のスクロール バーは DIV 内にないため、右の...

Docker チュートリアル: コンテナの使用 (簡単な例)

Docker を初めて使用する場合は、コンテナの管理を始めるために習得する必要がある基本的なコマン...

Linux のバックグラウンドで実行するいくつかの方法 (まとめ)

1. ノーフープハングアップ信号を無視してプログラムを実行する追加メモnohup コマンドは、ハン...

プロトタイプとプロトタイプチェーン プロトタイプとプロトタイプの詳細

目次1. プロトタイプ2. プロトタイプチェーン2.1 コンストラクタ2.2 電話をかける/申し込む...

HTMLからPDFへの変換のための純粋なクライアント側と純粋なサーバー側の実装ソリューション

必要ユーザーがフォームに入力して「保存」をクリックすると、PDF ドキュメントを直接ダウンロードでき...

インデックスは MySQL クエリ条件で使用されますか?

雇用主から MySQL クエリ条件でインデックスが使用されるかどうかを尋ねられた場合、どのように答え...

HTMLタグIDは変数にできる

<table id=" <%=var1%>">、var1...

MySQLの文字セットと検証ルールの詳細な説明

1いくつかの一般的な文字セットMySQL で最も一般的な文字セットには、ASCII 文字セット、ラテ...

Iframe の使用を減らすべきいくつかの理由の分析

次のグラフは、100 個の異なる要素で iframe を作成するのにどれくらいの時間がかかるかを示し...

VueはOSSを使用して画像や添付ファイルをアップロードします

OSS を使用して Vue プロジェクトに画像や添付ファイルをアップロードするここでは、写真のアップ...

js シンプルで粗雑なパブリッシュとサブスクライブのサンプルコード

パブリッシュ/サブスクライブとは何ですか?例を挙げてみましょう。あなたは服を買うために店に行きます。...

VMwareがwin10ホームバージョンに64ビットオペレーティングシステムをインストールできない問題を解決します

問題の説明VMware Workstationが新しい仮想マシンを作成し、64ビットオペレーティング...