Linux で Nginx ロード バランシングを使用して複数の Tomcat を構成する方法

Linux で Nginx ロード バランシングを使用して複数の Tomcat を構成する方法

Linux に nginx と複数の tomcat をインストールする方法はここでは紹介しません。不明な場合は、以下を参照してください。

Linux に nginx をインストールします。

https://www.jb51.net/article/159519.htm

Linux に複数の Tomcat をインストールする:

https://www.jb51.net/article/159521.htm

サーバーに nginx と複数の tomcat がインストールされたら、nginx の負荷分散を試してみることができます。

まず私の動作環境を簡単に紹介します

Alibaba Cloudサーバー、

Linuxシステム、jdk1.8、nginxがインストール済み、

4 つの Tomcat がインストールされており、それぞれ 8080、8081、8082、8083 に対応するポート番号が設定されています。


1: nginxディレクトリの下のconfディレクトリに入る

これは私の nginx インストール ディレクトリです:

[root@aliServer ~]# cd /usr/local/nginx/conf

2: nginx.confを編集する


[root@aliServer conf]# vi nginx.conf

3. サーバーグループを構成する

1: http{} ノード間にアップストリーム構成を追加します。 (localhost と書かないように注意してください。そうしないとアクセス速度が非常に遅くなります)

アップストリーム nginxDemo {
  server 127.0.0.1:8081; #サーバーアドレス1
  server 127.0.0.1:8082; #サーバーアドレス2
  server 127.0.0.1:8082; #サーバーアドレス 3
  server 127.0.0.1:8083; #サーバーアドレス 4
}

2: nginxがリッスンするポート番号80を変更する

nginx のデフォルト ポートは 80 です。まだ変更していません。

サーバー{
  listen 80; #デフォルトは80ですが、他のポート番号に変更できます。もちろん、占有されているポート番号は書き込めません。
  ......
}

3: proxy_passを使用してリバースプロキシアドレスを設定する

location\{} には、「http://」を含める必要があり、次のアドレスは最初のアップストリーム ステップで定義された名前と一致している必要があります (つまり、nginxDemo という名前はカスタマイズされており、2 つの場所は一致している必要があります)。

位置 / {
      ルートhtml;
      インデックス index.html index.htm;
      proxy_pass http://nginxDemo; #プロキシアドレスを設定する}

設定が完了すると、図に示すように次のようになります。


4: nginxを起動する

私のnginxのインストールパスは/usr/local/nginxです

私の起動コマンドは次のようになります:

[root@aliServer ~]# /usr/local/nginx/sbin/nginx

nginxは以前にインストールされたときに起動されていたため、再度起動するとポート番号が占有されているというエラーが報告されます。


今回は、各ポート番号の占有状況を表示するコマンドを使用します。

[root@aliServer ~]# netstat -ntpl 

nginx が PID 9097 で占有されていることがわかります。kill -9 を使用してこれを強制終了します。

[root@aliServer ~]# kill -9 9097

nginxを再度起動します

[root@aliServer ~]# /usr/local/nginx/sbin/nginx

応答がない場合は、ブラウザにサーバーアドレスを入力してください


これは、nginx が正常に起動したことを示しています。次に、構成が正しいかどうか、負荷を分散できるかどうかを確認しましょう。 。 。

5: 検証

nginx ロード バランシングを使用すると、すべてのクライアント リクエストが nginx を経由するため、nginx はこれらのリクエストを誰に転送するかを決定できることは周知の事実です。サーバー A のリソース (CPU、メモリなど) が多く、サーバー B の処理能力がサーバー A ほど強力でない場合、nginx はより多くのリクエストを A に転送し、サーバー B へのリクエストは少なくなります。このようにしてロード バランシングが実現され、サーバーの 1 つがダウンしても、ユーザーは引き続き Web サイトに通常どおりアクセスできます。

検証の前に、いくつかの準備が必要です。

1: 次のような単純な jsp を準備します。


1台のサーバーに4台のTomcatをインストールしたので、4つのindex.jspファイルを用意しました。

彼らです

<title>Tomcat8080<title> <h1>こんにちは、Tomcat_8080</h1>
<title>Tomcat8081<title> <h1>こんにちは、Tomcat_8081</h1>
<title>Tomcat8082<title> <h1>こんにちは、Tomcat_8082</h1>
<title>Tomcat8083<title> <h1>こんにちは、Tomcat_8083</h1>

ここで注意すべき点は、tomcat の起動が成功した場合の画面が図のようになるため、jsp ファイルの名前は index.jsp である必要があるということです。


tomcatインストールディレクトリのwebapps/ROOT/index.jspを読み取ります。

私のアドレスは: /usr/java/tomcat/tomcat_8080/webapps/ROOT


各 Tomcat のデフォルトの index.jsp ファイルを、前に準備した 4 つの index.jsp ファイルで上書きします。

各Tomcatを起動する

[root@aliServer bin]# ./startup.sh

このとき、ブラウザに xxx.xxx.xx.xx:8080 と入力すると、子猫が表示されなくなることがわかります。 。 。 。 。 。




4 台の Tomcat はすべて正常に起動し、nginx も正常に起動しました。

この時点で、ブラウザにサーバーの IP アドレスを入力し、ページを継続的に更新します。ページに 8080、8081、8082、8083 が表示されます。もちろん、これは nginx が、どのサーバーのリソースが十分であるかに基づいて、リクエストの送信先を決定するためです。ブラウザでのリクエストのアドレスは変更されませんが、異なる tomcat サーバーにアクセスします。これは、nginx が正常に構成されていることを意味します。

以上がこの記事の全内容です。皆様の勉強のお役に立てれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。

以下もご興味があるかもしれません:
  • Nginx リバース プロキシと負荷分散を実装する方法 (Linux ベース)
  • Linux システムでの nginx サーバーのインストールと負荷分散構成の詳細な説明
  • Linux で nginx ロード バランシングを構築する方法
  • Linuxシステム構成の詳細な説明 nginx ロードバランシング
  • Linux での Nginx 負荷分散構成の使用例の詳細な説明。

<<:  MySQL Community Server 圧縮パッケージのインストールと設定方法

>>:  JavaScript PromiseとAsync/Awaitの詳細な説明

推薦する

MySQL 分離列とプレフィックスインデックスの使用の概要

目次データ列を分離するプレフィックスインデックスとインデックスの選択性データ列を分離するMySQL ...

テーブル設定の背景画像が100%表示されない解決策

開発中に以下の状況が発見されました。 (1) ファイルが.jspファイル拡張子で保存されている場合、...

HTML ウェブページでのアンカー(名前付きアンカー)の使用の概要

以下の情報はインターネットから収集したものです1. アンカーは、Web ページ作成におけるハイパーリ...

標準的なHTMLの書き方は、Dreamweaverによって自動的に生成されるものとは異なります。

コードをコピーコードは次のとおりです。 <!--doctype はドキュメント タイプ htm...

ReactとReduxの配列処理の説明

この記事では、reduce()、filter()、map()、every()、some()、spre...

Bootstrapグリッドの垂直および水平配置の詳細な説明

目次1. Bootstrap グリッドレイアウト2. 垂直方向の配置2.1 行タグの垂直方向の配置を...

MySQL information_schema データベースの詳細な説明

1. 概要information_schema データベースは performance_schema...

VMware Workstation 12 Pro Linux インストール チュートリアル

この記事は、VMware Workstation 12 ProのインストールLinuxチュートリアル...

Vueのフロントエンドとバックエンドのポートの不一致の問題を解決する

Vue のフロントエンドとバックエンドのポートが一致していませんconfig index.jsファイ...

MySQLは間違ったパスワードを入力する試行回数を制御します

1. 本番環境でMySQLのデッドロックを監視し、デッドロックの可能性を減らす方法まず、デッドロック...

Centos6.5 で MySQL 5.7.19 をインストールして設定する方法

Centos6.5にmysql5.7.19をインストールするための詳細な手順は次のとおりです。 1....

一般的なMysql DDL操作の概要

図書館管理ライブラリを作成する データベースを作成します [存在しない場合] ライブラリ名;ライブラ...

Tomcat10 Catalinaのログの文字化けの問題を解決する

実行環境、Idea2020バージョン、Tomcat10、実行時にTomcat CatalinaLog...

プライベートウェアハウス(レジストリとハーバー)を構築するためのDockerの実装

使用される Docker イメージが増えるにつれて、イメージを保存する場所、つまりウェアハウスが必要...

Vue フォーム入力バインディング v-model

目次1.vモデル2. プロパティとイベントのバインディング3. フォーム要素のバインディング3.1 ...