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 つのパラダイム

推薦する

Vue.jsでタブ切り替えと色変更操作を実装する解説

この機能を実装するにあたり、本家ブロガーさんから拝借した方法では色の切り替えが実現できず、長い間考え...

JS はシンプルなカレンダー効果を実装します

この記事では、シンプルなカレンダー効果を実現するためのJSの具体的なコードを参考までに紹介します。具...

CocosCreator 入門チュートリアル: TS で初めてのゲームを作る

目次前提TypeScript と JavaScriptコードエディタの選択TypeScriptを学ぶ...

電子メールの HTML ページを作成するための原則の概要

HTML メールはこのサイト上の独立したホスト ページではないため、他の誰かによってホストされていま...

カスタム変数を使用した MySQL クエリの最適化

目次並べ替えクエリの最適化変更されたばかりのデータ行を繰り返し取得しないようにする遅延ロードされた結...

優れたユーザー エクスペリエンス デザイナーが行うべき 5 つのこと (画像とテキスト)

この記事は、@C7210 によって翻訳されたブログ「Usability Counts」からの翻訳です...

Confluence と jira-software を Docker にデプロイする方法

バージョン: セントロス==7.2 jdk==1.8 合流==6.15.4 jira-ソフトウェア=...

mysql 8.0.19 winx64.zip インストール チュートリアル

この記事は参考までにmysql 8.0.19 winx64.zipのインストールチュートリアルを記録...

nginx をベースにリロードなしでアップストリーム サーバーの動的な自動起動と停止を実装する方法

目次1. Consulクラスタをデプロイする1. 準備3. Consulクラスタを作成する4. 管理...

Alibaba Cloud ドメイン名と IP バインディングの手順と方法

1 Alibaba Cloud コンソールに入り、ドメイン名コンソールを見つけて、バインドするドメイ...

HTML 5 ワーキングドラフトの謎を解く

World Wide Web Consortium (W3C) は、HTML 5 仕様のドラフトをリ...

ディスク容量不足による MySQL レプリケーション障害の解決方法

目次ケースシナリオ問題を解決するまとめケースシナリオ本日、オンラインで問題が発見されました。監視範囲...

Idea で Tomcat のソースコードデバッグを開始し、デバッグのために Tomcat に入る方法

idea 開発ツールを使用してコードをデバッグする場合、Java Web プロジェクトで、Web コ...

Vue+thinkphp5.1+axiosでファイルアップロードを実現

この記事では、thinkphp5.1 + Vue+axiosを使用してファイルをアップロードする方法...

Win7 インストール MySQL 5.6 チュートリアル図

目次1. ダウンロード2. インストール3. my.ini ファイルを設定する(デフォルトのエンコー...