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セレクターでの正規表現の使用

推薦する

CSS3 のテキストとフォントの新しい設定

テキストシャドウテキストシャドウ: 水平オフセット 垂直オフセット ぼかし色互換性: IE10+ &...

Vueはプルダウンを実装してさらに読み込む

Element-UI に慣れた開発者なら、無限スクロールの InfiniteScroll が使いにく...

CentOS 6.5 インストール mysql5.7 チュートリアル

1. 新機能MySQL 5.7 はエキサイティングなマイルストーンです。デフォルトの InnoDB ...

Dreamweaver8を使用してウェブサイトのファイルをチェックして整理する方法

Dreamweaver8 を使用して独自の Web サイトを作成する目的は何ですか?インターネットに...

JavaScript WeakMap の使い方の詳しい説明

WeakMap オブジェクトは、キーが弱参照であるキー/値のペアのコレクションです。キーはオブジェク...

Vue を通じて QR コードスキャン機能を実装する

ヒントこのプラグインは https プロトコルでのみアクセスできます。http プロトコルはうまく機...

JSはストップウォッチタイマーを実装します

この記事の例では、ストップウォッチタイマーを実装するためのJSの具体的なコードを参考までに共有してい...

Vue2 における 12 種類のコンポーネント通信

目次1. 小道具2..同期3.vモデル4.参照5. $emit/v-on 6. $attrs/$li...

Nginx サーバーの https 設定方法の例

Linux: Linux バージョン 3.10.0-123.9.3.el7.x86_64 ngin...

React tsx はランダムな検証コードを生成します

React tsxは参照用にランダムな検証コードを生成します。具体的な内容は次のとおりです。最近、t...

MySQLは既存のコンテンツを保持し、後でコンテンツを追加します

このコマンドは、データ テーブル ff_vod を変更し、vod_url フィールドの内容の後に 9...

mysql5.7.20 での最初のログイン失敗に対する簡単な解決策

まず、 (1)MySQL 5.7にはデフォルトのパスワードがあるデフォルトのパスワードを見つける g...

ページコンテンツ全体を中央に配置して、高さがコンテンツに合わせて自動的に拡張されるようにする方法

ページコンテンツ全体を中央に配置する方法と、コンテンツに合わせて高さを自動的に拡大縮小する方法。これ...

MySQLで大きなテーブルを正常に削除する方法の詳細な説明

序文テーブルを削除するには、無意識に思い浮かぶコマンドは、DROP TABLE "テーブル...