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 マスタースレーブ構築(複数のマスターと 1 つのスレーブ)の実装アイデアと手順

背景:最近、同社のプロジェクトは同時実行のプレッシャーに耐えられないようなので、最適化が差し迫ってい...

MySQL 5.7.18 のダウンロードとインストールの詳細な手順

MySql ダウンロード1. 公式サイトを開き、ダウンロード パスを見つけます。ダウンロード アドレ...

MySQL のマスタースレーブレプリケーションと読み取り書き込み分離の原理と使用法の詳細な説明

この記事では、例を使用して、MySQL マスター/スレーブ レプリケーションと読み取り/書き込み分離...

JSに関する7つの面接の質問、あなたはいくつ正しく答えられますか

序文JavaScript では、これは関数呼び出しコンテキストです。この動作が非常に複雑であるからこ...

MySQL DISTINCTの基本実装原理の詳細な説明

序文DISTINCT は、GROUP BY 操作の実装と非常によく似ていますが、GROUP BY の...

MySQLシリーズ マルチテーブル結合クエリ92および99構文例詳細チュートリアル

目次1. デカルト積現象2. 接続クエリの知識ポイントのまとめ1) 結合クエリとは何ですか? 2) ...

メタビューポートはiPhoneでウェブページをフルスクリーン表示コントロールします

困り果てて、ふと、私がよく行くSinaのタッチスクリーン版はどうやって作られているのだろう?と考えま...

jQuery でダイナミックなパーティクル効果を実現

この記事では、動的なパーティクル効果を実現するためのjQueryの具体的なコードを参考までに紹介しま...

nginx + セカンダリドメイン名 + https サポートを使用する

ステップ1: Alibaba Cloudプライマリドメイン名にセカンダリドメイン名を追加する2 番目...

テーブルを使用してフォームコントロールの形式を調整し、見栄えを良くします。

自分でウェブページを書きたいので、HTML 言語についても少し勉強しています。これは、大学時代にウェ...

Yahooのフロントエンド最適化に関する35のルールについての簡単な説明

概要: 仕事でも面接でも、Web フロントエンドのパフォーマンスを最適化することは非常に重要です。で...

子ども向けウェブサイトの視覚構造レイアウト設計手法の分析

1. 温かくて優しい関連アドレス: http://www.web-designers.cn/post...

関連するプロパティのリストを含む HTML エリア イメージ ホットスポットの使用の概要

<area> タグは主にイメージマップで使用されます。イメージマップにアクティブ領域 (...

Jenkins の docker-compose デプロイメントと構成に関する詳細なチュートリアル

Docker-compose デプロイメント構成 Jenkins 1. Docker-compose...