Nginx サービス クイック スタート チュートリアル

Nginx サービス クイック スタート チュートリアル

1. Nginx の紹介

1. Nginx とは何ですか?

  • Nginx (エンジン x) は、IMAP/POP3/SMTP サービスも提供する高性能 HTTP およびリバース プロキシ Web サーバーです。
  • その特徴は、メモリの占有量が少なく、強力な同時実行機能を備えていることです。実際、nginx の同時実行機能は、同じタイプの Web サーバー間でより優れたパフォーマンスを発揮します。

2. Nginx を使用する理由

今日のインターネットの急速な発展により、シングルポイント サーバーでは、数万、あるいは数十万のユーザーからの継続的なアクセスをサポートできなくなっています。たとえば、理想的な条件下では、Tomcat サーバーは約 2,000 件の同時リクエストしか処理できません。この問題を解決するには、負荷分散のために複数の Tomcat サーバーが必要です。

では、負荷分散はどのように実現すればよいのでしょうか? Nginx はソリューションの 1 つです。ユーザーが Web サイトにアクセスすると、Nginx はアクセス要求をインターセプトし、ポーリングを通じてさまざまなサーバーに均等に分散します。

さらに、Nginx には ip_hash 戦略があり、ユーザーの実際の IP を取得し、ハッシュ値を計算してサーバーを選択できます。これも優れた負荷分散方法です。 したがって、Nginx を習得することは、Web 開発の学習過程において不可欠な部分となっています。

3. フォワードプロキシとは何ですか?

フォワード プロキシとは、クライアントが最初にプロキシ サーバーに要求を送信し、次にプロキシ サーバーがその要求をサーバーに転送することを意味します。私たちがよく使うVPNはプロキシサーバーです。海外のウェブサイトに接続するには、クライアントが外部ネットワークに接続できるサーバーをプロキシとして利用する必要があり、クライアントはプロキシサーバーに接続することができます。

4. リバースプロキシとは何ですか?

リバース プロキシはフォワード プロキシとは異なります。フォワード プロキシはクライアントのプロキシとして機能し、リバース プロキシはサーバーのプロキシとして機能します。複数のサーバーが分散されている場合、クライアントが IP アドレスを通じて同じ Web サイトにアクセスできるようにするには、リバース プロキシが必要です。

リバース プロキシの動作メカニズムを理解したら、Nginx の学習を開始できます。

2. LinuxでのNginxのインストール

Nginx は Web サーバーで広く使用されているため、このチュートリアルではデモとして Centos サーバーのバージョン 7.4 を選択します。

1. ダウンロード

公式ダウンロード ページ (http://nginx.org/en/download.html) にアクセスし、安定バージョンを選択してダウンロードし、サーバーにアップロードします。

2. インストール

tarパッケージをサーバーにアップロードした後、現在のディレクトリに解凍します。

tar -zxvf nginx-1.18.0.tar.gz -C ./

解凍したディレクトリに入り、configureスクリプトを実行します。

nginx-1.18.0/をインストールします
./configure

makeコマンドを使用してインストールする

作成 && インストール

インストールが完了したら、whereis コマンドを使用して Nginx のインストール場所を見つけます (デフォルトでは /user/local/ ディレクトリにインストールされます)。

nginxはどこにある?

インストール ディレクトリの下の bin フォルダーに入り、nginx サービスを開始し、サーバーのデフォルト ポート 80 にアクセスして、インストールが成功したかどうかを確認します。

3. Nginx 設定の開始

1. 設定ファイル

Nginx インストール ディレクトリに conf フォルダーがあります。その中の nginx.conf ファイルを開きます。

cd conf/ && vim nginx.conf 

2. 単一サーバーのリバースプロキシ

では、リバース プロキシに Nginx を使用するにはどうすればよいでしょうか?

location パラメータに proxy_pass フィールドを追加し、リバース プロキシを必要とするサーバー アドレスとポート番号を入力します。

注意: 設定の各行はタイトルで終わる必要があります。 ! !

#リスニングディレクトリを次のように設定します: /
位置 / {
	ルートhtml;
	インデックス index.html index.htm;
	proxy_pass http://127.0.0.1:8080; # ローカルマシンのポート 8080 のリバースプロキシ # proxy_pass http://127.0.0.1:8081; # 複数の proxy_pass を同時に設定できます。ローカルマシンのポート 8081 のリバースプロキシ}

3. 複数のサーバーをリバースプロキシする

サーバーが複数ある場合はどうなりますか? proxy_pass パラメータを継続的に追加することに加えて、アップストリーム サーバー グループを構成することがより良い解決策です。

設定ファイルの http ブロックにアップストリーム属性を追加します。

# helloという名前のサーバーグループを設定します
アップストリームこんにちは{
	# 1 つのサーバーは 1 つのサーバーに対応します。もちろん、異なるポートを持つ Web プログラムにすることもできます。server 127.0.0.1:8080;
	サーバー 127.0.0.1:8081;
}
# ロケーションブロック内のリバースプロキシをサーバーグループのロケーション/{に変更します
	ルートhtml;
	インデックス index.html index.htm;
	proxy_pass http://hello; # hello サーバー グループ内のすべてのサーバーをリバース プロキシします}

4. テストを実行する

1. サービスを開始する

設定が完了したら、Nginx インストール ディレクトリの下の sbin フォルダーに移動し、nginx プログラムを実行します。

ローカル

以前に起動したことがある場合は、nginx サービスをシャットダウンする必要はなく、nginx に設定ファイルを再読み込みさせるだけです。

nginx -s リロード

ブラウザを更新します。リバース プロキシが成功すると、アクセスされたパスが構成ファイル内のサーバー アドレスに自動的にマップされます。

将来、ユーザー数が増えていくと、新しいサーバーを追加する必要が生じる可能性があります。このとき、nginx サーバーをシャットダウンせずに、設定ファイルを変更し、nginx -s reload コマンドを使用するだけで済みます。

2. サービスをシャットダウンする

nginx サービスをシャットダウンするには、通常 2 つの方法があります。

nginx -s stop # 動作しているかどうかに関係なく、すぐに停止します nginx -s quit # プロセスが現在の作業を完了するまで待機し、安全に終了します

5. 負荷分散

1. 負荷分散とは何ですか?

サーバーごとに構成が異なるため、高性能サーバーにより多くのリクエストを割り当てられるように、負荷分散の概念が導入されました。

前述のように、Nginx には、加重ラウンドロビン (デフォルト)、IP ハッシュ、URL ハッシュなど、多くの負荷分散方法があります。ここでは、加重ラウンドロビンを紹介します。

加重ラウンドロビンとは、サーバーに重み値を追加することで、Nginx が重みに基づいてリクエストを分散することを意味します。重みが高いほど、受信するリクエストの数が多くなり、逆もまた同様です。

上図では、3 台のサーバーが構成されています。重み付けポーリング モードでは、6 つの異なるリクエストのうち、重みが 3 のサーバーには 3 つのリクエストが、重みが 2 のサーバーには 2 つのリクエストが、重みが 1 のサーバーには 1 つのリクエストが割り当てられます。負荷分散により、同時実行性の高い環境でのサーバーダウンタイムのリスクが大幅に軽減されます。

2. Nginxのロードバランシングを設定する

同様に、nginx.conf ファイルを開いて設定します。

vim nginx.conf

上流ブロックに重みパラメータを追加します。

アップストリームこんにちは{
	server server1:8080 weight=3; # server1の重みを3に設定する
	server server2:8080 weight=1; # server2の重みを1に設定する
}

追加後、nginx -s reload! を実行してください。

上記は、Nginx サービスのクイックスタートチュートリアルの詳細な内容です。nginx 入門チュートリアルの詳細については、123WORDPRESS.COM の他の関連記事に注目してください。

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

<<:  Vueのシンプルストアの詳しい説明

>>:  W3C チュートリアル (5): W3C XML アクティビティ

推薦する

MySQL の最初のインストールが成功した後にパスワードを初期化する手順

ファイルをディレクトリに解凍しますこれは解凍後のディレクトリですmy.iniファイルを入力しますダブ...

Linuxでファイルを削除してもスペースが解放されない問題の対処方法

問題の背景業務システムのサーバ監視システムからディスク使用率が90%に達したという早期警告通知が来た...

Reactにおける制御されたコンポーネントと制御されていないコンポーネントの簡単な分析

目次制御されていないコンポーネント制御コンポーネント知らせ結論は制御されていないコンポーネントフォー...

Javascript ファイルと Blob の詳細な説明

目次ファイル()文法パラメータ例ブロブ()文法パラメータ財産方法例要約するファイル() File()...

HTML埋め込みタグの使用方法と属性の詳細な説明

1. 基本的な文法コードをコピーコードは次のとおりです。埋め込み src=url注: 埋め込みはさま...

Html+CSS フローティング広告ストリップの実装

1.html部分コードをコピーコードは次のとおりです。 <!DOCTYPE html> ...

CentOS7にMySQL 8.0.26をインストールする手順

1. まず、お使いのマシンに応じて、MySQL 公式サイトから対応するデータベースをダウンロードしま...

MySQL でタイムスタンプを日付に変換する例

序文職場で次のような状況に遭遇しました。ログ システムのテーブルでは、時間フィールドには日付データで...

WeChatアプレットAmapマルチポイントルート計画プロセス例の詳細な説明

電話Amap API を呼び出す方法は? Amap が https://lbs.amap.com/a...

Win10 での MySQL 5.7 の詳細なインストールと設定のチュートリアル

1. MySQL 5.7を解凍する2. 新しい設定ファイルmy.iniを作成し、 D:\Free\m...

React の調整アルゴリズム Diffing アルゴリズム戦略の詳細な説明

目次アルゴリズム戦略単一ノードの差分配列ノードの差分キー値の使用要件アルゴリズム戦略React の調...

MySQL インデックス プッシュダウンを 5 分で学ぶ

目次序文インデックス プッシュダウンとは何ですか?インデックスプッシュダウン最適化の原理インデックス...

Linux 継続的インテグレーションで Maven を自動的にインストールする方法

Mavenパッケージを解凍する tar xf apache-maven-3.5.4-bin.tar....

Ubuntu での CUDA と CUDNN のインストールとアンインストールの実装

目次序文グラフィックドライバーをインストールするCUDAをアンインストールするCUDAをインストール...

MySQL で左結合を使用して where 条件を追加する問題の詳細な分析

現在の需要:グループとファクターの 2 つのテーブルがあります。1 つのグループは複数のファクターに...