nginx で仮想ホストを構成するための詳細な手順

nginx で仮想ホストを構成するための詳細な手順

仮想ホストは、インターネット上で実行されているサーバー ホストを複数の「仮想」ホストに分割する特殊なソフトウェアおよびハードウェア テクノロジを使用します。各仮想ホストは、独立したドメイン名と完全なインターネット サーバー機能 (WWW、FTP、電子メールなど) を備えた独立した Web サイトにすることができます。同じホスト上の仮想ホストは完全に独立しています。ウェブサイト訪問者の観点から見ると、各仮想ホストはスタンドアロン ホストとまったく同じです。

ここに画像の説明を挿入

仮想ホストを使用すると、実行する Web サイトごとに個別の Nginx サーバーを用意したり、個別の Nginx プロセス セットを実行したりする必要がありません。仮想ホストは、同じサーバー上および同じ Nginx プロセス セット上で複数の Web サイトを実行する機能を提供します。

仮想ホストを構成する方法は 3 つあります。

  • ドメイン名ベースの仮想ホスティング: 異なるドメイン名、同じ IP (この方法が最も広く使用されています)
  • ポートベースの仮想ホスティング: 異なるサイトのコンテンツを区別するためにドメイン名や IP アドレスを使用する代わりに、異なる TCP ポート番号が使用されます。
  • IPアドレスに基づく仮想ホスト: 異なるドメイン名、異なるIPアドレス(ネットワークインターフェースを追加する必要があり、あまり使用されていない) IPアドレスに基づく

ここに画像の説明を挿入

方法 1: 複数のネットワーク カードと複数の IP

2つの物理ネットワークカード、2つのIP

# 2 つの物理ネットワーク カード ens32 と ens34
[root@nginx ネットワーク スクリプト]# ifconfig ens32 | awk 'NR==2 {print $2}'  
192.168.126.41

[root@nginx ネットワーク スクリプト]# ifconfig ens34 | awk 'NR==2 {print $2}'  
192.168.126.42

設定ファイルを編集して、各IPに基づいて仮想ホストを作成します。

# /etc/nginx/conf.d/default.conf 設定ファイルに影響が及ばないようにするには、名前を [root@nginx ~] に変更します。# mv /etc/nginx/conf.d/default.conf /etc/nginx/conf.d/default	 

[root@nginx ~]# vim /etc/nginx/conf.d/ip.conf
# ens32 ネットワークカードに対応する仮想ホストサーバー {
  192.168.126.41:80 を聞きます。

  位置 / {
    ルート /ip_ens32;
    インデックス index.html;
  }
}

# 仮想ホストサーバーに対応するens34ネットワークカード{
  192.168.126.42:80 を聞きます。

  位置 / {
    ルート /ip_ens34;
    インデックス index.html;
  }
}

仮想ホストのWebページファイルディレクトリとファイルを作成する

[root@nginx ~]# mkdir /ip_ens32
[root@nginx ~]# mkdir /ip_ens34

[root@nginx ~]# echo "ens32" > /ip_ens32/index.html
[root@nginx ~]# echo "ens34" > /ip_ens34/index.html

設定ファイルの構文を確認してください

[root@nginx ~]# nginx -t
nginx: 設定ファイル /etc/nginx/nginx.conf の構文は正常です
nginx: 設定ファイル /etc/nginx/nginx.conf のテストが成功しました

nginx サービスを再読み込みする

[root@nginx ~]# systemctl reload nginx

テスト

[root@nginx ~]# カール 192.168.126.41
ens32
[root@nginx ~]# カール 192.168.126.42
ens34 

ここに画像の説明を挿入ここに画像の説明を挿入

方法 2: 複数の IP アドレスを持つ単一のネットワーク カード

1つの物理ネットワークカードに複数のIPを設定する

ip addr add IP/MASK dev ネットワークカード名# delete ip addr del IP/MASK dev ネットワークカード名

残りの手順は、上記のマルチNICマルチIP構成と同じです。

ポートベース

ここに画像の説明を挿入

ドメイン名が使用できない、または存在しない場合に社内で主に使用されます

構成

[root@nginx ~]# vim /etc/nginx/conf.d/port.conf
サーバー{
  聞く 81;

  位置 / {
    ルート /port_81;
    インデックス index.html;
  }
}

サーバー{
  聞く 82;

  位置 / {
    ルート /port_82;
    インデックス index.html;
  }
}

[root@nginx ~]# mkdir /port_{81..82}
[root@nginx ~]# echo "81" > /port_81/index.html
[root@nginx ~]# echo "82" > /port_82/index.html

[root@nginx ~]# nginx -t
nginx: 設定ファイル /etc/nginx/nginx.conf の構文は正常です
nginx: 設定ファイル /etc/nginx/nginx.conf のテストが成功しました
[root@nginx ~]# systemctl reload nginx

テスト

[root@nginx ~]# カール 192.168.126.41:81
81
[root@nginx ~]# カール 192.168.126.41:82
82 

ここに画像の説明を挿入ここに画像の説明を挿入

ドメイン名に基づく

ここに画像の説明を挿入

構成

通常、1 つのドメイン名は 1 つの構成ファイルに対応するため、管理が容易です。

[root@nginx ~]# vim /etc/nginx/conf.d/test1.dxk.com.conf
サーバー{
  聞く 80;
  サーバー名 test1.dxk.com;

  位置 / {
    ルート /test1;
    インデックス index.html;
  }
}

[root@nginx ~]# vim /etc/nginx/conf.d/test2.dxk.com.conf
サーバー{
  聞く 80;
  サーバー名 test2.dxk.com;

  位置 / {
    ルート/test2;
    インデックス index.html;
  }
}

[root@nginx ~]# mkdir /test{1..2}
[root@nginx ~]# echo "test1" > /test1/index.html
[root@nginx ~]# echo "test2" > /test2/index.html

[root@nginx ~]# nginx -t
nginx: 設定ファイル /etc/nginx/nginx.conf の構文は正常です
nginx: 設定ファイル /etc/nginx/nginx.conf のテストが成功しました

[root@nginx ~]# systemctl reload nginx

テスト

# ドメイン名解決を設定する [root@nginx ~]# echo -e "192.168.126.41 test1.dxk.com\n192.168.126.41 test2.dxk.com" >> /etc/hosts
[root@nginx ~]# cat /etc/hosts
127.0.0.1 ローカルホスト ローカルホスト.ローカルドメイン ローカルホスト4 ローカルホスト4.ローカルドメイン4
::1 ローカルホスト ローカルホスト.ローカルドメイン ローカルホスト6 ローカルホスト6.ローカルドメイン6
192.168.126.41 テスト1.dxk.com
192.168.126.41 テスト2.dxk.com

[root@nginx ~]# curl test1.dxk.com
テスト1
[root@nginx ~]# curl test2.dxk.com
テスト2 

ここに画像の説明を挿入
ここに画像の説明を挿入
ここに画像の説明を挿入

問題は次の通りです:

ドメイン名の解決が正しく構成されていない場合、間違ったドメイン名にアクセスしたときに Web ページのコンテンツが返されます (間違ったドメイン名の仮想ホストが構成されていません)。

[root@nginx ~]# vim /etc/hosts
192.168.126.41 テスト1.dxk.com
192.168.126.41 test3.dxk.com # これは test2.dxk.com であるはずですが、誤って記述されており、test3.dxk.com ドメイン名に対応する仮想ホストが存在しません。

間違ったドメイン名にアクセスする

[root@nginx ~]# curl test3.dxk.com
テスト1

# ご覧のとおり、Webページの情報は引き続き返されます

ドメイン名解決を設定する際に、ドメイン名が間違って記述されていても、IP は正しいためです。この場合、サーバーはデフォルトで、IP とポート 80 に一致する最初の仮想ホストの Web ページ情報をクライアントに返します。

[root@nginx ~]# ll /etc/nginx/conf.d/
-rw-r--r--。1 ルート ルート 112 7月 3日 21:23 test1.dxk.com.conf
-rw-r--r--。1 ルート ルート 112 7月 3日 21:22 test2.dxk.com.conf

これは注目すべきことだ

nginx 仮想ホストに関するこの記事はこれで終わりです。より関連性の高い nginx 仮想ホストのコンテンツについては、123WORDPRESS.COM の以前の記事を検索するか、以下の関連記事を引き続き参照してください。皆様が今後も 123WORDPRESS.COM を応援してくれることを願っています。

以下もご興味があるかもしれません:
  • Nginx で仮想ホストと指定されたアクセス パスを設定する方法
  • Nginx 仮想ホスト設定例 (複数のウェブサイト構成)
  • Nginx 仮想ホストを構成する 3 つの方法 (ドメイン名に基づく)
  • nginx 仮想ホスト設定例の詳細な説明
  • Nginx 仮想ホストの詳細な分析
  • Nginx の仮想ホストに関するあまり知られていない知識のまとめ

<<:  HTML の左右レイアウトのサンプルコード

>>:  CSSセレクターでの正規表現の使用

推薦する

Linux での MySql centos7 のバイナリコンパイルとインストールに関するチュートリアル

// これをインストールするのに丸一日かかったので、記録するためにメモを書きました。 //何か問題が...

フロントエンドコンポーネント化の基礎知識を詳しく解説

目次コンポーネントの基本概念オブジェクトとコンポーネントの違い成分属性属性とプロパティ属性:財産:ク...

CentOS での mysql5.7 の詳細なインストールと設定のチュートリアル

インストールユーザーにインストール権限があることを確認してくださいルートスイッチなしsuルート(su...

Webサービスのリモートデバッグとタイムアウト動作原理の分析

Webサービスのリモートデバッグ.NET では、WEBSERVICE のリモート デバッグ機能はデフ...

JavaScript の寄生的構成継承についての簡単な説明

コンポジション継承組み合わせ継承は、疑似古典的継承とも呼ばれます。これは、昨日説明したプロトタイプ ...

Docker での Redis の最も詳細なインストールと構成 (画像とテキスト付き)

1. Dockerに適したRedisのバージョンを見つけるdocker hubで見つけることができ...

ユニアプリとミニプログラム(画像とテキスト)を下請けする方法を教えます

目次1. ミニプログラム下請け2. Uniapp 下請けアプレット下請けの手順: 1. manife...

MySQL 8.0 パスワード有効期限ポリシーの詳細な説明

MySQL 8.0.16 以降では、パスワードの有効期限ポリシーを設定できます。今日は、この小さな知...

ページキャッシュを無効にするいくつかの方法を共有する

本日、開発中に、顧客からページをキャッシュしないように要求される方法に遭遇しました。調べたところ、ペ...

ミニプログラム録画機能の実装

序文ミニプログラムを開発する過程では、録音機能を実装し、録音を再生し、録音をサーバーにアップロードす...

要素の$notifyポイントについての簡単な説明

当初の意図は、element-ui の $notify 通知をコンポーネントにカプセル化することでし...

VMware で Nginx+KeepAlived クラスタ デュアルアクティブ アーキテクチャを展開する際の問題と解決策

序文負荷分散には nginx を使用します。アーキテクチャのフロントエンドまたは中間層として、トラフ...

Vue3 における親コンポーネントと子コンポーネント間の値の転送の詳細な説明

vue3 が誕生してからかなり時間が経ち、筆者も最近になって vue3 を学び始めました。 vue2...

Viteプロジェクトを作成する手順

目次序文yarn create は何をしますか?ソースコード分析プロジェクトの依存関係テンプレート構...

Vue.js と MJML でレスポンシブなメールを作成する

MJML は、開発者が美しく、応答性に優れ、あらゆるデバイスやメール クライアントで動作する魅力的な...