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の詳細な説明

推薦する

Windows が MySQL サービスを開始できず、エラー 1067 を報告する場合の解決策

突然、MySQLにログインすると、アクセスが拒否されたか、データベースに接続できないと表示されました...

MySQLを水平から垂直に、垂直から水平に変換する方法

データの初期化 `test_01` が存在する場合はテーブルを削除します。 テーブル「test_01...

mysql charset=utf8 本当に意味が分かりますか

1. まずテーブル作成ステートメントを見てみましょう テーブル学生を作成( sid int 主キー ...

Vue は URL に基づいて非同一オリジンのファイルをどのようにダウンロードするのか

一般的に、URL に基づいてファイルをダウンロードする場合、次の 2 つの解決策があります。 1. ...

ウェブページで Enter キーを押すと自動的にフォームを送信し、他のページにジャンプするソリューション

ウェブページでEnterキーを押すと、フォームは自動的に送信され、他のページに移動します。クエリフォ...

要素のフォームコンポーネントに関する注意事項

要素フォームとコード表示詳細はエレメントフォーム公式サイトをご覧ください構造と機能の分析紹介とソース...

nginx ssl を設定して https アクセスを実装する手順 (初心者向け)

序文サーバーを展開した後、私は大きな喜びを感じながら自分の Web サイトにアクセスし、見たものすべ...

HTML+CSS+JavaScript でシンプルな三目並べゲームを作成する

目次HTMLの実装CSSを追加Javascript部分の実装デモアドレス HTMLの実装まず、hea...

CentOS7 に MySQL データベースをインストールしてデバッグする詳細な手順 [例]

この例では、デバッグ用の MySQL データベースをダウンロードしてインストールする必要があります。...

Nginxはhttpリクエスト実装プロセス分析を処理する

Nginxはまず、設定ファイル内のどのserver{}ブロックを処理に使用するかを決定します。次のs...

数千万のデータを扱うMySQLのページングクエリのパフォーマンスを最適化する

MySQL のデータ量が多い場合、制限ページングが使用されます。ページ数が増えると、クエリの効率が低...

Vue Element フロントエンドアプリケーション開発開発環境の準備

目次概要1. 必要なソフトウェア環境を開発する1) VSコードのインストール2) ノード開発環境をイ...

Web プロジェクト開発 JS 機能の手ぶれ補正とスロットリングのサンプル コード

目次安定導入手ぶれ補正シーン1(マウスの動き込み)手ぶれ補正シーン2(キーボードのキー)関数のスロッ...

JavaScript の基礎: エラーキャプチャメカニズム

目次序文エラーオブジェクト投げる試して…捕まえて…最後に最終ルールトライ/キャッチパフォーマンスウィ...

コードの互換性を高めるために、HTMLを次のように記述します。

たとえば、スクリーン リーダー ソフトウェアを必要とするユーザーなどです。フロントエンド開発者として...