Docker ベースの Tomcat クラスタと Nginx ロード バランシングの展開の概要

Docker ベースの Tomcat クラスタと Nginx ロード バランシングの展開の概要

前面に書かれた

Doccer関連の書籍を読んでいたところ、たまたまこれを必要とするプロジェクトがあったので、自分で実践してみました。

それを百の人生として扱ってください。ここでの論理は非常に明確です。私は考える、ゆえに私は存在する。私は存在するので、存在しないふりをすることはできない。何があっても、自分の責任は自分で取らなければなりません。 ——王暁波「30歳にして」


構造図:

ここに画像の説明を挿入

あくまでも勉強用です。一般的には、この程度の負荷であれば、主機側Nginxを配置し、コンテナ内にJavaWeb(Tomcat)アプリケーションを配置します。

効果

ここに画像の説明を挿入

新しいフォルダーを作成します。

D=uag;mkdir $D;cd $D;mkdir uag_nginx uag_tomcat8;
 ls
 uag_nginx uag_tomcat8

1. Ngixnイメージの作成

uag_nginx/ をCDに追加します
# 設定ファイルを保存するのに使用します mkdir nginx
vim Dockerファイル

Dockerfileの内容

nginxから
ラベル メンテナー="uag"
環境更新日時 2021-08-27

エクスポーズ8099

nginx設定ファイルのコンテンツを構築する

この構成ファイルは、コンテナの実行時に-vパラメータを通じてコン​​テナと共有されます。後でパラメータを変更するのに便利

cd ./nginx
vim nginx.conf

nginx.conf 設定ファイルの内容

ユーザー nginx;
ワーカープロセスは自動です。

error_log /var/log/nginx/error.log 通知;
pid /var/run/nginx.pid;
デーモンオフ;

イベント {
    ワーカー接続 1024;
}


http {
    /etc/nginx/mime.types を含めます。
    デフォルトタイプ アプリケーション/オクテットストリーム;

    log_format main '$upstream_addr - $remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';

    access_log /var/log/nginx/access.log メイン;

    ファイル送信オン;
    #tcp_nopush オン;

    キープアライブタイムアウト65;

    #gzip オン;

    /etc/nginx/conf.d/*.conf を含めます。

    サーバー{
        聞く 8099;
        server_name ローカルホスト;

        ルート /var/www/html/;
        インデックス index.html index.htm;

        access_log /var/log/nginx/default_access.log メイン;
        error_log /var/log/nginx/default_error.log;

        
        位置 / {
                proxy_pass http://backend;
        }

        場所 ~ .* {
                        proxy_pass http://backend;
                        proxy_set_header ホスト $http_host;
                        proxy_set_header X-Real-IP $remote_addr;
                        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
                }

        

}
    # ここでロードアップストリームバックエンドを設定します {
    サーバー 172.23.231.190:8069;
    サーバー 172.23.231.190:8079;
    サーバー 172.23.231.190:8089;
}
}

負荷を構成します172.23.231.190はホスト IP、8069、8079、8089 は対応する Java Web 公開アプリケーション ポートです。

 # ここでロードアップストリームバックエンドを設定します {
    サーバー 172.23.231.190:8069;
    サーバー 172.23.231.190:8079;
    サーバー 172.23.231.190:8089;
}

Nginxイメージをビルドする

uag/uag_nginx を実行します。

2. Java Web (Tomcat) アプリケーションイメージの構築

cd uag_tomcat8/

vim Dockerファイル

Dockerfileの内容

dordoka/tomcatより
メンテナー LIRUILONG

UAWeb.war をコピー /opt/tomcat/webapps/UAWeb.war

エクスポーズ8080

エントリポイント [ "/opt/tomcat/bin/catalina.sh", "run" ]

対応するWarパッケージをアップロードする

ls
Dockerファイル UAWeb.war

イメージを構築する

uag/uag_tomcat を実行します。

3. コンテナのNginxイメージを実行する

docker run -d -p 8099:8099 --name uag_nginx -v $PWD/nginx/nginx.conf:/etc/nginx/nginx.conf uag/uag_nginx nginx

Java Web (Tomcat) イメージ

docker run -it -d -p 8089:8080 --name uag_app_1 uag/uag_tomcat
 docker run -it -d -p 8079:8080 --name uag_app_2 uag/uag_tomcat
 docker run -it -d -p 8069:8080 --name uag_app_3 uag/uag_tomcat

実行中のコンテナを表示する

ここに画像の説明を挿入

ブラウザアクセス

ここに画像の説明を挿入

ロードモードの表示: 新しいプロセスのモード

ここに画像の説明を挿入

ロードモードの表示: –volumes-from mode

Dockerファイル

nginxから
ラベル メンテナー="uag"
環境更新日時 2021-08-27

ボリューム /var/log/nginx/
エクスポーズ80
┌──(liruilong㉿Liruilong)-[/mnt/e/docker/uag/uag_nginx]
└─$ docker run -it --rm --volumes-from nginx_log centos cat /var/log/nginx/default_access.log
172.23.231.190:8069 - 172.17.0.1 - - [30/Aug/2021:12:55:02 +0000] "GET /UAWeb/services/listServices HTTP/1.1" 200 12660 "http://127.0.0.1:8099/UAWeb/" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/92.0.4515.159 Safari/537.36" "-"

172.23.231.190:8079 - 172.17.0.1 - - [30/Aug/2021:12:55:02 +0000] "GET /UAWeb/axis2-web/css/axis-style.css HTTP/1.1" 200 1587 "http://127.0.0.1:8099/UAWeb/services/listServices" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/92.0.4515.159 Safari/537.36" "-"
172.23.231.190:8069 - 172.17.0.1 - - [30/Aug/2021:12:55:02 +0000] "GET /UAWeb/axis2-web/images/asf-logo.gif HTTP/1.1" 200 5866 "http://127.0.0.1:8099/UAWeb/services/listServices" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/92.0.4515.159 Safari/537.36" "-"
172.23.231.190:8079 - 172.17.0.1 - - [30/Aug/2021:12:55:02 +0000] "GET /UAWeb/axis2-web/images/axis_l.jpg HTTP/1.1" 200 12340 "http://127.0.0.1:8099/UAWeb/services/listServices" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/92.0.4515.159 Safari/537.36" "-"
172.23.231.190:8089 - 172.17.0.1 - - [30/Aug/2021:12:55:03 +0000] "GET /UAWeb/services/listServices HTTP/1.1" 200 12660 "http://127.0.0.1:8099/UAWeb/" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/92.0.4515.159 Safari/537.36" "-"
172.23.231.190:8069 - 172.17.0.1 - - [30/Aug/2021:12:55:03 +0000] "GET /UAWeb/axis2-web/images/asf-logo.gif HTTP/1.1" 200 5866 "http://127.0.0.1:8099/UAWeb/services/listServices" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML、Gecko など) Chrome/92

イメージをビルドしてリポジトリにアップロードします。

ここに画像の説明を挿入

Docker Hub賬號を登録し、ログインして、賬戶名/

┌──(liruilong㉿Liruilong)-[/mnt/e/docker/uag/uag_nginx]
└─$ docker push liruilong/nginx_log
プッシュはリポジトリ [docker.io/liruilong/nginx_log] を参照します。
タグ liruilong/nginx_log を持つイメージがローカルに存在しません

┌──(liruilong㉿Liruilong)-[/mnt/e/docker/uag/uag_nginx]
└─$ docker tag 9c9af0362eb9 liruilong/nginx_log

┌──(liruilong㉿Liruilong)-[/mnt/e/docker/uag/uag_nginx]
└─$ docker push liruilong/nginx_log
プッシュはリポジトリ [docker.io/liruilong/nginx_log] を参照します。
fb04ab8effa8: プッシュ
8f736d52032f: プッシュ
009f1d338b57: 押された
678bbd796838: プッシュ
d1279c519351: プッシュ
f68ef921efae: プッシュされました
最新: ダイジェスト: sha256:2af7e8aeab84e8a816caf6b0342e1a45f95c7089ff52578040ea3a4c28a943c7 サイズ: 1570

┌──(liruilong㉿Liruilong)-[/mnt/e/docker/uag/uag_nginx]
└─$ docker push liruilong/nginx_log:tagname # イメージをプルする

ここに画像の説明を挿入

これで、Docker ベースの Tomcat クラスターと Nginx ロード バランシングのデプロイに関するこの記事は終了です。Docker を使用した Tomcat Nginx ロード バランシングのデプロイの詳細については、123WORDPRESS.COM の以前の記事を検索するか、次の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • Nginx+Tomcat 負荷分散クラスタのインストールと構成のケースの詳細な説明
  • Nginx+Tomcat 負荷分散クラスタの実装例
  • Nginx+tomcat ロードバランシングクラスタの実装方法
  • Nginx 経由で Tomcat9 クラスターを構築し、セッション共有を実現する
  • Nginx で Tomcat クラスターを構築する方法

<<:  音楽プレーヤーアプリ(アプリケーションソフトウェア)の分析と再設計 美しい音楽プレーヤーインターフェースの設計方法

>>:  CSS プロパティ display:flow-root 宣言を 1 つの記事でマスターする

推薦する

React における ref の一般的な使用法の概要

目次Refsとは何か1. 文字列型参照2. コールバック参照React.createRef() 4....

Element UI を使用してページにページング ナビゲーション バーを追加する方法

必要ページング バーを追加します。これにより、ページにジャンプしたり、ページ番号に従って特定のページ...

MySQLトリガーの例の詳細な説明

目次トリガーとは何かトリガーを作成する複数の実行ステートメントを持つトリガーの作成制限と考慮事項要約...

JavaScript を使用してページに動的な検証コードを実装する例

導入:現在、プログラム攻撃を防ぐために、ユーザーがログインまたは登録するときに多くの動的検証テクノロ...

Vue-Jest自動テストの基本構成の詳しい説明

目次インストール構成よくある間違い事前テスト作業依存関係の扱いインスタンスとDOMを生成する要約する...

Linux (Ubuntu) での MySQL 5.7.17 のインストールと設定のチュートリアル

序文以前、MySQL 5.6 をインストールしました。3 か月後、開発者から MySQL で JSO...

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

はい、CSS にも正規表現があります (アーメン) CSS で目立つための 2 つの強力なツール: ...

JavaScriptでマクロを使用する方法

言語では、DSL を実装するためにマクロがよく使用されます。マクロを使用すると、開発者は JSX 構...

@media レスポンシブ CSS を使用してさまざまな画面に適応する例

定義と使用@media クエリを使用すると、さまざまなメディア タイプに異なるスタイルを定義できます...

jsは古典的なマインスイーパゲームを実装します

この記事の例では、古典的なマインスイーパゲームを実装するためのjsの具体的なコードを参考までに共有し...

シンプルなスネークを実現するためのネイティブjsキャンバス

この記事では、参考までに、簡単なスネークゲームを実装するためのjsキャンバスの具体的なコードを共有し...

CSS3 のフィルタプロパティの使用に関する詳細な説明

最近、イントラネットポータルを修正していたときに、フィルターを使用する必要がある箇所に遭遇しました。...

Vue要素ヘッダーにスラッシュを追加するための実装コード

<テンプレート> <div class="アプリコンテナ"&...

docker コマンド例外「権限が拒否されました」の解決方法

Linuxシステムでは、dockerを新しくインストールし、次のようなコマンドを入力します。dock...

MySQL共通ストレージエンジンの機能と使用方法の詳細な説明

この記事では、一般的な MySQL ストレージ エンジンの機能と使用方法を例を使って説明します。ご参...