Dockerカスタムネットワーク実装

Dockerカスタムネットワーク実装

1. コンテナ相互接続を実現するためにネットワークをカスタマイズする

4種類のネットワークモード。docker network lsを使用してdockerネットワークモードを表示します。

Docker ネットワーク モード構成例示する
ホストモード–net=ホストコンテナとホストはネットワーク名前空間を共有します。
コンテナモード–net=コンテナ:NAME_or_IDコンテナは別のコンテナとネットワーク名前空間を共有します。 Kubernetes のポッドは、ネットワーク名前空間を共有する複数のコンテナです。
なしモード–net=なしコンテナには独立したネットワーク名前空間がありますが、veth ペアやブリッジ接続の割り当て、IP の構成などのネットワーク設定は実行されません。
ブリッジモード–net=ブリッジブリッジモード(このモードがデフォルトです)

–net=bridge これはデフォルト値であり、デフォルトのブリッジに接続します。

–net=host は、コンテナ ネットワークを分離された名前空間に配置しないように、つまりコンテナ内のネットワークをコンテナ化しないように Docker に指示します。この時点で、コンテナはローカル ホストのネットワークを使用し、ローカル ホスト インターフェイスに完全にアクセスできます。コンテナ プロセスは、ホスト上の他のルート プロセスと同様に低範囲ポートを開き、D-bus などのローカル ネットワーク サービスにアクセスし、ホストの再起動など、ホスト システム全体に影響する操作をコンテナが実行できるようにすることができます。したがって、このオプションは慎重に使用してください。 --privileged=true をさらに使用すると、コンテナはホストのネットワーク スタックを直接構成できるようになります。

–net=container:NAME_or_ID は、新しく作成されたコンテナ プロセスを既存のコンテナのネットワーク スタックに配置するように Docker に指示します。新しいコンテナ プロセスには独自のファイル システム、プロセス リスト、およびリソース制限がありますが、IP アドレスやポートなどのネットワーク リソースは既存のコンテナと共有されます。2 つのプロセスは、lo ループバック インターフェイスを介して直接通信できます。

–net=none は、Docker に新しいコンテナを分離されたネットワーク スタックに配置するように指示しますが、ネットワーク構成は行いません。その後はユーザーが自分で設定できます。

カスタムネットワーク

# --driver bridge ブリッジモード# --subnet 192.168.0.0/16 サブネットセグメント# --gateway 192.168.0.1 ゲートウェイ# mynet ネットワーク namedocker ネットワーク作成 --driver bridge --subnet 192.168.0.0/16 --gateway 192.168.0.1 mynet

ここに画像の説明を挿入

カスタマイズされたネットワーク情報を表示します。

docker ネットワーク検査 mynet 

ここに画像の説明を挿入

カスタムネットワークにコンテナを作成する

docker run -d -P --name tomcat01-net-01 --net mynet tomcat
docker run -d -P --name tomcat01-net-02 --net mynet tomcat

ここに画像の説明を挿入

カスタム ネットワーク情報を再度確認します。新しく作成された 2 つのコンテナーがネットワークに追加されていることがわかります。

ここに画像の説明を挿入

コンテナ名を使用してコンテナ間のpingテストを行う

tomcat01-net-01 が tomcat01-net-02 に ping を送信します:

ここに画像の説明を挿入

tomcat01-net-02 が tomcat01-net-01 に ping を送信します:

ここに画像の説明を挿入

これで、コンテナは --link を使用せずに相互に ping を実行できるようになり、コンテナは相互に通信できるようになります。

2. ネットワーク接続

需要分析図

ここに画像の説明を挿入

tomcat01 と tomcat02 の 2 つのコンテナを作成します。

docker run -d -P --name tomcat01 tomcat
docker run -d -P --name tomcat02 tomcat

ここに画像の説明を挿入

当然ですが、直接 ping を実行することはできません。まず tomcat01 コンテナを mynet ネットワークに接続する必要があります。

docker ネットワーク接続

docker network connect コマンドは、docker コンテナをネットワークに接続するために使用されます。コンテナ名またはコンテナ ID を使用できます。

使用法:

docker network connect [オプション] ネットワークコンテナ

tomcat01 コンテナを mynet ネットワークに接続します。

docker ネットワーク接続 mynet tomcat01

mynet のネットワーク情報を表示します: docker inspect mynet

ここに画像の説明を挿入

tomcat01 はすでに mynet ネットワークに接続されており、tomcat01-net-tomcat01 および tomcat01-net-tomcat02 も同様です。

この時点で、tomcat01 は mynet ネットワーク内の 2 つのコンテナに接続されています。3 つのコンテナは同じネットワーク内にあるため、当然相互に通信できます。

ここに画像の説明を挿入

1 つのコンテナ、2 つのネットワーク:

tomcat01 のメタデータを表示します: docker inspect tomcat01

ここに画像の説明を挿入

tomcat01 がカスタム mynet ネットワークに接続されると、2 つのネットワークが存在します。

Docker でのカスタム ネットワーク実装に関するこの記事はこれで終わりです。Docker ネットワークに関するより関連性の高いコンテンツについては、123WORDPRESS.COM の過去の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • Dockerのネットワークモードと設定方法
  • Docker は固定コンテナ IP アドレスを実現するためにカスタム ネットワークを作成します。
  • Docker Compose ネットワーク設定の説明

<<:  HTMLフロートの使用法の簡単な分析

>>:  CSS3は三角形の連続拡大効果を実現します

推薦する

Vueのドラッグ可能なコンポーネントであるVue Smooth DnDの使用方法の詳細な説明

目次紹介とデモAPI: コンテナ財産ライフサイクルコールバックイベントAPI: ドラッグ可能実際の戦...

HTMLはキャンバスを使用して箇条書きスクリーン機能を実装します

導入最近、大きな課題をこなす際に、弾幕プレイヤーを作る必要がありました。他の人のソースコードを借りて...

フロントエンドページのスライド検証を実装するための JavaScript + HTML

この記事では、フロントエンドページのスライド検証を実装するためのJavaScript + HTMLの...

MYSQL トランザクション チュートリアル Yii2.0 マーチャント引き出し機能

序文私はプログラマーとしてスタートした PHP プログラマーです。これまで、トレーニング コースで勉...

Vueのミックスインと継承について詳しく説明します

目次序文ミキシンMixin ノート (重複名)ローカルミックスイングローバル ミックスイン継承するミ...

Expressプロジェクトファイルディレクトリの説明と詳細な機能の説明

app.js: スタートアップファイル、またはエントリファイルpackage.json: プロジェク...

Dockerは公式Redisイメージをインストールし、パスワード認証を有効にします

参考: Docker 公式 Redis ドキュメント1. 特別なバージョン要件がある場合は、redi...

CentOS8.0 で FTP サーバーをインストールして設定する方法

CentOS8.0-1905 のリリース後、FTP サーバーを CentOS の新しいバージョンに移...

MySQL mysqladmin クライアントの使用の概要

目次1. サーバーの状態を確認します。 2. ルートパスワードを変更します。 3. mysqlser...

Dockerがsudo操作を使用する必要がある問題を解決する

手順は以下のとおりです1. dockerグループを作成する: sudo groupadd docke...

MySQL が重複データを挿入するのを防ぐ 3 つの方法

新しいテーブルを作成する テーブル「人」を作成します( `id` int NOT NULL COMM...

MySQL セキュリティ管理の詳細

目次1. 順番に紹介する2. ユーザーを作成する3. ユーザーアカウントを削除する4. アクセス権5...

Zabbixで指定時間内の変化値を設定する方法の詳細な説明

背景説明: 既存の負荷分散装置には、付加価値状態にある指標があります (増加するだけで減少しないため...

Vueのデータ応答性原則の詳細な説明

この記事は主に、Vue のレスポンシブ ソース コードを理解していない、または触れたことがない人向け...