Docker Compose を使用して nginx のロード バランシングを実装する方法

Docker Compose を使用して nginx のロード バランシングを実装する方法

Dockerネットワーク管理とコンテナIP設定に基づいてNginxロードバランシングを実装する

すべてのDockerネットワークを表示

docker ネットワーク ls

/*
ネットワーク ID 名前 ドライバー スコープ
b832b168ca9a ブリッジ ブリッジ ローカル
373be82d3a6a composetest_default ブリッジ ローカル
a360425082c4 ホスト ホスト ローカル
154f600f0e90 なし null ローカル

*/

// composetest_default は、前回の記事で Compose を紹介したときに docker-compose.yml ファイルが配置されているディレクトリ名です。
// そのため、docker-composeで作成されたコンテナは、デフォルトでディレクトリ名をネットワーク名としてネットワークを作成し、ドリッジ(ブリッジ)タイプになります。

コンテナのIPアドレスを指定する

公式ウェブサイトのドキュメントアドレス: https://docs.docker.com/compose/compose-file/#ipv4_address-ipv6_address

前回の記事「12. Docker Compose コンテナオーケストレーションツールの使用」から引き続き docker-compose.yml ファイルを書きます。

バージョン: "3"
サービス:
  ウェブ1:
    コンテナ名: web1
    画像: "centos:httpd"
    ポート:
      - 「8080:80」
    特権: true
    ボリューム:
      - "/app/www/web1/:/var/www/html/"
    コマンド: ['/usr/sbin/init']
    ネットワーク:
      nginx-lsb:
        ipv4_アドレス: 192.169.0.3
  ウェブ2:
    コンテナ名: web2
    画像: "centos:httpd"
    ポート:
      - 「8081:80」
    特権: true
    ボリューム:
      - "/app/www/web2/:/var/www/html/"
    コマンド: ['/usr/sbin/init']
    ネットワーク:
      nginx-lsb:
        ipv4_アドレス: 192.169.0.2
ネットワーク:
  nginx-lsb:
    ドライバー: ブリッジ
    ipam:
      設定:
        - サブネット: 192.169.0.0/16

docker-composeを使用してコンテナを起動します

docker-compose を起動 -d

コンテナが起動しているか、ネットワーク nginx-lsb が作成されているかを確認します。

// 現在の docker-compose.yml で設定されたコンテナグループ内のコンテナステータスを表示できます docker-compose ps

docker ネットワーク ls

/*
ネットワーク ID 名前 ドライバー スコープ
b832b168ca9a ブリッジ ブリッジ ローカル
373be82d3a6a composetest_default ブリッジ ローカル
de6f5b8df1c8 composetest_nginx-lsb ブリッジ ローカル
a360425082c4 ホスト ホスト ローカル
154f600f0e90 なし null ローカル
*/

// コンテナ グループ プロジェクト ファイル名_ネットワーク名の先頭にちなんで名付けられた nginx-lsb ネットワークを作成しました

ネットワーク nginx-lsb の詳細を表示

docker ネットワーク検査 composetest_nginx-lsb

// 詳細では、このネットワークを使用している各コンテナの IP アドレスを確認できます。

のように:

/*
...
 「コンテナ」: {
      "039aa860ef04f20a7566fdc943fb4398a61d2ad6dd3e373b17c86ac778af89e3": {
        "名前": "web2",
        "エンドポイントID": "1bc206661179e65999015f132c2889d3d4365b8d42b8a89cf9c260016fedd5ee",
        "Macアドレス": "02:42:c0:a9:00:02",
        "IPv4アドレス": "192.169.0.2/16",
        "IPv6アドレス": ""
      },
      "437ad7a07da8e46c0abaf845c4b08425338009fbe972bde69478cf47c75c315b": {
        "名前": "web1",
        "エンドポイントID": "5a36e602a5364ee9ad06e9816d09e3966d56ebf06b9394ebc25b8bcee9546607",
        "Macアドレス": "02:42:c0:a9:00:03",
        "IPv4アドレス": "192.169.0.3/16",
        "IPv6アドレス": ""
      }
    },
...
*/

env_file 環境ファイルを使用します:

簡単に言えば、docker-compose.ymlで変数を定義し、外部の.envファイルで参照するということです。

公式ドキュメントのアドレス: https://docs.docker.com/compose/compose-file/#env_file

// または、composetest ディレクトリに .env ファイルを定義して、変数 web1_addr=192.169.0.2 を保存します。
web2_addr=192.169.0.3

// docker-compose.yml ファイルを変更し、変数定義 version: "3" を追加します。
サービス:
  ウェブ1:
    コンテナ名: web1
    画像: "centos:httpd"
    ポート:
      - 「8080:80」
    特権: true
    ボリューム:
      - "/app/www/web1/:/var/www/html/"
    コマンド: ['/usr/sbin/init']
    ネットワーク:
      nginx-lsb:
        ipv4_address: ${web1_addr}
  ウェブ2:
    コンテナ名: web2
    画像: "centos:httpd"
    ポート:
      - 「8081:80」
    特権: true
    ボリューム:
      - "/app/www/web2/:/var/www/html/"
    コマンド: ['/usr/sbin/init']
    ネットワーク:
      nginx-lsb:
        ipv4_address: ${web2_addr}
ネットワーク:
  nginx-lsb:
    ドライバー: ブリッジ
    ipam:
      設定:
        - サブネット: 192.169.0.0/16

composetestプロジェクトを再起動し、ネットワークの詳細をチェックして、コンテナIPが正常に設定されているかどうかを確認します。

// composetestプロジェクトを再起動する docker-compose up -d

// ネットワークの詳細を表示 docker network examine composetest_nginx-lsb

composetest プロジェクトに nginx サーバーを負荷分散サーバーとして追加します。

// .env ファイルに変数 nginx_lsb を追加します
web1_addr=192.169.0.2
web2_addr=192.169.0.3
nginx_lsb = 192.169.0.100

// docker-compose.yml ファイルを変更し、変数定義 version: "3" を追加します。
サービス:
  nginx-lsb:
    コンテナ名: nginx-lsb
    画像: "centos:nginx"
    ポート: 
      - 「8000:80」
    特権: true
    ボリューム:
      - 「/app/nginx/nginx.conf:/etc/nginx/nginx.conf」
    ネットワーク:
      nginx-lsb:
        ipv4_アドレス: ${nginx_lsb}
  ウェブ1:
    コンテナ名: web1
    画像: "centos:httpd"
    ポート:
      - 「8080:80」
    特権: true
    ボリューム:
      - "/app/www/web1/:/var/www/html/"
    コマンド: ['/usr/sbin/init']
    ネットワーク:
      nginx-lsb:
        ipv4_address: ${web1_addr}
  ウェブ2:
    コンテナ名: web2
    画像: "centos:httpd"
    ポート:
      - 「8081:80」
    特権: true
    ボリューム:
      - "/app/www/web2/:/var/www/html/"
    コマンド: ['/usr/sbin/init']
    ネットワーク:
      nginx-lsb:
        ipv4_address: ${web2_addr}
ネットワーク:
  nginx-lsb:
    ドライバー: ブリッジ
    ipam:
      設定:
        - サブネット: 192.169.0.0/16

// composetestプロジェクトを再起動する docker-compose up -d

nginx.conf設定ファイルを変更し、負荷分散を設定する

アップストリーム mydocker {
  サーバー 192.169.0.2;
  サーバー 192.169.0.3;
}

サーバー{
  聞く 80;
  サーバー名 mydocker;
  位置 / {
    proxy_set_header ホスト $host;
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    proxy_buffering をオフ;
    proxy_pass http://mydocker;
  }
}

nginx-lsbを再起動して設定ファイルをロードします

docker-composer で nginx-lsb を再起動します

サーバーの負荷分散をテストするには、http://serverIP address:8000 にアクセスしてください。

注: 前回の記事では、異なる Web ファイルが 2 つの httpd サーバーに配置されていました。

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

以下もご興味があるかもしれません:
  • 負荷分散と動的および静的分離操作を実現するDocker NginxコンテナとTomcatコンテナ
  • Docker を使用して nginx で tomcat クラスターを構築する方法 (画像とテキスト付き)
  • nginxとdockerを使用してシンプルな負荷分散を実現する詳細な説明
  • Docker ベースの Tomcat クラスタと Nginx ロード バランシングの展開の概要

<<:  Taobao の商品画像切り替え効果を実現する JavaScript

>>:  JavaScript の実行コンテキストとコールスタックの詳細な説明

推薦する

MySQL オンライン DDL ツール gh-ost 原理分析

目次1. はじめに1.1 原則1.2 プロセス1.3 特徴1.4 githubアドレス2. テスト環...

W3C チュートリアル (14): W3C RDF および OWL アクティビティ

RDF と OWL は、2 つの重要なセマンティック ウェブ テクノロジーです。 RDF と OWL...

Navicat Premiumを使用してMySQLデータベースにリモート接続する方法

新しい接続を作成する側がクライアントに相当し、接続される側がサーバーに相当します。手順は次のとおりで...

vue3+electron12+dll 開発のためのクライアント構成の詳細な説明

目次リポジトリソースを変更する起動するvue-devtoolsを置き換える予防ボーダーレスウィンドウ...

MySQLデータベーストリガーの詳細な説明

目次1 はじめに2 トリガーの紹介3 トリガーを作成する4 トリガーを表示5. トリガーの削除6 結...

上位Nを見つけるためのMySQLグループソートの詳細な説明

MySQLグループソートで上位Nを見つけるテーブル構造grp でグループ化し、num で並べ替えて、...

Navicat for MySQL 15 登録とアクティベーションの詳細なチュートリアル

1. Navicat for MySQL 15をダウンロードするhttps://www.navica...

要素テーブルからヘッダーを削除する方法

show-header属性を使用したドキュメントのヒントshow-header <el-テーブ...

iptables および firewalld ツールを使用して Linux ファイアウォール接続ルールを管理する

ファイアウォールファイアウォールは一連のルールです。パケットが保護されたネットワーク空間に出入りする...

MySQL クイックデータ比較テクニック

MySQL の運用と保守において、R&D の同僚が 2 つの異なるインスタンスのデータを比較...

Linux exa コマンド (ls よりも優れたファイル表示エクスペリエンス)

インストールREADMEに従ってインストールしてくださいドキュメントには、exa は Rust で実...

MySQL スロークエリ関連パラメータの原理の分析

MySQL スロー クエリ (正式名称はスロー クエリ ログ) は、MySQL によって提供されるロ...

アプレットにおけるwx.getUserProfileインターフェースの具体的な使用

最近、WeChatミニプログラムは、監査ミニプログラムのwx.loginおよびwx.getUserI...

CocosCreator でレイヤー管理に常駐ノードを使用する方法

CocosCreator バージョン: 2.3.4ほとんどのゲームにはレイヤー管理機能があり、例えば...