Docker コンテナ データ ボリュームの名前付きマウントと匿名マウントの問題

Docker コンテナ データ ボリュームの名前付きマウントと匿名マウントの問題

コンテナデータボリュームとは

コンテナデータボリュームはディレクトリのマウントです。コンテナのディレクトリはホストマシンにマウントされ、ホストマシンとコンテナ間のファイル共有機能を実現します。

コンテナ データ ボリュームが必要なのはなぜですか?

Docker の考え方は、アプリケーションと環境をイメージにパッケージ化することですが、データはどうでしょうか?データベースはもちろん、プロジェクトでは運用中に大量のログが生成されます。これらのログは開発者にとって非常に重要です。これらのログがあれば、運用中にどのような問題が発生したかを把握し、トラブルシューティングを行うことができます。

しかし、コンテナでは、プロジェクトが更新されて反復されるたびに、コンテナが削除され、新しいイメージに置き換えられます。この場合、これらのログファイルを保存したい場合、毎回ホストマシンにコピーすると、作業負荷が少し大きくなり、ログファイルが大きすぎると、コピー作業にも非常に時間がかかり、労力がかかります。そのため、このときは、コンテナデータボリューム機能を使用する必要があります。簡単に言えば、この機能は非常にシンプルで、ホストとコンテナ間のファイル共有機能を開くことです。Dockerコンテナで生成されたデータファイルは、リアルタイムでホストマシンに同期されます。逆に、ホストマシンで生成されたファイルもコンテナに同期されます。このようにして、双方向の伝送パイプラインが開かれます。

ここに画像の説明を挿入

コンテナ間でデータ共有が実装されると、共有データのコピーが 1 つだけ存在し、それがホスト マシンに保存されるため、メイン コンテナとサブ コンテナの区別がなくなります。いずれかのコンテナを削除しても、他のコンテナのデータ同期には影響しません。

ここに画像の説明を挿入

使用

コンテナ データ ボリュームの使用は非常に簡単です。実行時に-vオプションを追加するだけです。

docker run -d -v ホストディレクトリ: コンテナディレクトリ tomcat

上記のコマンドを実行すると、コンテナとホスト上に対応するディレクトリが自動的に作成され、ディレクトリ内で作成または変更されたファイルが自動的に同期されます。

データボリュームが使用されているかどうかを確認する方法

コンテナがコンテナ データ ボリューム機能を使用しているかどうかを確認するには、 inspect機能を使用してコンテナの詳細情報を表示します。

docker コンテナ ID/コンテナ名を検査する

上記のコマンドを実行すると、フォーマットされた JSON 文字列が多数出力されます。この時点で、キーMountsを持つ項目がコンテナ データ ボリュームの関連構成であることがわかります。

「マウント」: [
    {
        「タイプ」:「バインド」  
        "Source": "/root/dockerContainer", # ホストマシンのディレクトリ "Destination": "/text", # コンテナのディレクトリ "Mode": "",
        "RW": true、# RW は読み取りおよび書き込み可能です。ro は読み取り専用で、ホスト マシン上のファイルのみを変更できます。 
        「伝播」: 「rprivate」
    }
]、

名前付きマウントと匿名マウント

パスを指定してマウントする

上記の例では、指定されたパスマウントを使用します。つまり、ホスト パスとコンテナー パスを構成します。

docker run -d -v ホストディレクトリ: コンテナディレクトリ tomcat

名前付きマウント

指定された名前のディレクトリにマウントします。

# /xxx はディレクトリ、xxx はボリューム名、スラッシュのない方がボリューム名です docker run -d -v ボリューム名: コンテナ ディレクトリ tomcat 

# ボリューム名があるディレクトリを探す docker volume examine volume name

テストしてみましょう。まず、コンテナを作成し、ディレクトリをマウントします。

docker run -d --name my_tomcat -v my_folder:/data/my_folder tomcat

コンテナ情報を表示するにはinspectコマンドを使用します

docker で my_tomcat を検査する

印刷された情報でMounts項目を見つけます。 Sourceディレクトリはホスト ディレクトリ、 Destinationディレクトリはマウントされたコンテナー ディレクトリです。

「マウント」: [
    {
        「タイプ」:「ボリューム」、
        "名前": "my_folder",
        「ソース」: 「/var/lib/docker/volumes/my_folder/_data」、
        「宛先」: 「/data/my_folder」、
        "ドライバー": "ローカル",
        "モード": "z",
        「RW」:真、
        「伝播」: 「」
    }
]

次にコンテナに入ります

docker exec -it my_tomcat /bin/bash

# このディレクトリはコンテナ内にも作成されています root@ef94ff8928a1:/data/my_folder# pwd
/データ/私のフォルダ

匿名マウント

匿名マウントとは、コンテナ ディレクトリのみが存在し、ホスト ディレクトリが存在しないことを意味します。そのため、生成されるディレクトリは長い暗号化された文字列になります。一般に、匿名マウントは推奨されません。暗号化された文字列は見つけにくくなるためです。

docker run -d -v \コンテナディレクトリ tomcat

さあ、テストしてみましょう。まずコンテナを作成し、ディレクトリをマウントします。

docker run -d --name my_tomcat_2 -v /my_folder_2 tomcat

コンテナ情報を表示するにはinspectコマンドを使用します

docker で my_tomcat_2 を検査する

印刷された情報でMounts項目を見つけます。 Sourceディレクトリはホストディレクトリ、 Destinationディレクトリはマウントされたコンテナディレクトリです。

「マウント」: [
    {
        「タイプ」:「ボリューム」、
        「名前」: 「df4c649772a5ae65716de8ede0607d0776f8c1e2eda1d87b3ec9eaf011b43616」、
        「ソース」: 「/var/lib/docker/volumes/df4c649772a5ae65716de8ede0607d0776f8c1e2eda1d87b3ec9eaf011b43616/_data」、
        「宛先」: 「/my_folder_2」、
        "ドライバー": "ローカル",
        "モード": "",
        「RW」:真、
        「伝播」: 「」
    }
]

コンテナ間のデータ共有 - ボリューム -

コンテナ A とコンテナ B でデータを共有する必要があるシナリオがあります。つまり、コンテナ A で変更されたコンテンツをコンテナ B で確認したいのです。では、この機能はどのように実現すればよいのでしょうか?次に、データ ボリューム コンテナー機能を使用できます。この機能では、2 つのコンテナーだけでなく、複数のコンテナー間でデータを同期することもできます。

1. 最初のコンテナ centos_1 を作成し、ホストに /data/centos ディレクトリをマウントします。ホストとコンテナのディレクトリは両方とも/data/centosです。

docker run -it --name centos_1 -v /data/centos:/data/centos centos /bin/bash

2. 2 番目のコンテナを作成し、それを最初のコンテナにバインドします。-- --volumes-from centos_1オプションは、現在のコンテナのマウント ディレクトリを centos_1 コンテナにバインドし、コンテナ間のデータ同期を実現します。

docker run -it --name centos_2 --volumes-from centos_1 centos /bin/bash

3. 3番目のコンテナを作成し、2番目のコンテナcentos_2にバインドします。

docker run -it --name centos_3 --volumes-from centos_2 centos /bin/bash

次に、各コンテナの/data/centosディレクトリにファイルを作成します。

  • ホストマシンの/data/centosディレクトリにmain.javaファイルを作成します。
  • centos_1コンテナの/data/centosディレクトリにcentos_1.javaファイルを作成します。
  • centos_2 コンテナの /data/centos ディレクトリにcentos_2.javaファイルを作成します。
  • centos_3コンテナの/data/centosディレクトリにcentos_3.javaファイルを作成します。

最後に、4つの環境の/data/centosディレクトリでlsコマンドを実行すると、すべてのコンテナで作成されたファイルを確認できます。このようにして、コンテナ間のデータ同期を実現できます。

[root@259efdc362b4 centos]# ls
centos_1.java centos_2.java centos_3.java メイン.java

これで、docker コンテナ データ ボリューム (名前付きマウントと匿名マウント) に関するこの記事は終了です。docker コンテナ データ ボリュームに関する関連コンテンツについては、123WORDPRESS.COM の以前の記事を検索するか、次の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • Dockerの匿名マウントと名前付きマウントの具体的な使用法
  • Docker での名前付きマウントと匿名マウントの実装

<<:  Node.js のイベント モジュールに関する知識ポイントのまとめ

>>:  MySQL 学習: 初心者のための 3 つのパラダイム

推薦する

Linux 環境変数とプロセス アドレス空間の概要

目次Linux 環境変数とプロセスアドレス空間コードを通じて環境変数を取得するプロセスアドレス空間な...

mysql5.7.17 zip の解凍とインストールの詳細な手順

1. ダウンロードアドレスhttps://dev.mysql.com/downloads/mysql...

Vue + Axios リクエストインターフェース方式とパラメータ渡し方式の詳しい説明

目次1. リクエストを取得する: 2. 投稿リクエスト: 3. 拡張と補足Vue スキャフォールディ...

Linux仮想マシンを作成し、仮想マシンネットワークを設定する方法に関するVMwareの詳細なチュートリアル

VMware で Linux 仮想マシンを作成し、VMware と仮想マシンのネットワークを設定する...

CentOS7にMariaDB 10.2.4をインストールする方法の詳細な説明

CentOS 6 以前のバージョンでは、MySQL サーバー/クライアント インストール パッケージ...

nginxディレクトリパスをリダイレクトする方法

ドメイン名に続くパスがデフォルトの Web ディレクトリではなく、ローカル ディスク上の他のディレク...

mysql8.0.20 のデータディレクトリを移行する方法

mysql のデフォルトのストレージ ディレクトリは/var/lib/mysql/です。以下は、デフ...

HTML のフォームフォームのメソッド属性の紹介

1 メソッドは、データをサーバーに送信する方法を指定するプロパティです。 2 post と get ...

Java を Mysql バージョン 8.0.18 に接続する方法の詳細な説明

JavaとMysql 8.0.18バージョンの接続方法については、参考までに具体的な内容は以下のとお...

Linux での Jenkins の詳細なインストール手順

目次1. JDKをインストールする2. Jenkinsをインストールする3. Jenkinsの設定を...

VMware 仮想マシンの 3 つの接続方法の例の分析

NATこのようにして、仮想マシンのネットワーク カードはホストの VMnet8 に接続されます。この...

Mysql データベース ストアド プロシージャの基本構文の説明

プロシージャ sp_name を削除します//これまで、MYSQL 構文の基礎知識について説明して...

MySQL 結合クエリ構文と例

接続クエリ:これは、2 つのクエリ (またはテーブル) の各行をペアで接続した結果です。つまり、1 ...

MySQL 挿入時間の 8 時間の違いの問題の解決方法

MySQL挿入時の8時間の時差の問題を解決する通常、jdbc の URL にはいくつかのパラメータを...

Vue コンポーネント ライブラリ ElementUI はテーブル読み込みツリー データのチュートリアルを実装します

ElementUIは、参考のためにテーブルツリーリストの読み込みチュートリアルを実装しています。具体...