Dockerでボリュームを管理する2つの方法

Dockerでボリュームを管理する2つの方法

前回の記事では、Dockerの基礎知識であるローカルディレクトリのマウント方法を紹介しました。今日は、Dockerでデータボリュームを管理する2つの方法を紹介します。具体的な内容は以下のとおりです。

データボリュームとは

データ量:ボリュームとは、1 つ以上のコンテナー内に存在する特定のファイルまたはフォルダーです。このディレクトリは、ユニオン ファイル システムから独立した形式でホスト マシン内に存在し、データの共有と永続化を容易にします。

データ ボリュームを使用する理由は何ですか?

Docker 階層化ファイルシステムの問題:
Docker イメージは一連の読み取り専用レイヤーで構成されています。コンテナを起動すると、Docker はイメージのすべての読み取り専用レイヤーを読み込み、その上に読み取り/書き込みレイヤーを追加します。この設計により、Docker はイメージの構築、保存、配布の効率を向上させ、時間とストレージ スペースを節約できます。ただし、次のような問題もあります。
1. パフォーマンスが悪い。
2. 複数のコンテナ間でデータを共有することはできません。
3. ライフサイクルはコンテナのライフサイクルと同じです。コンテナを削除すると、コンテナによって生成されたデータは失われます。データ ボリューム メカニズムの利点:
1. 階層化ファイルシステムをバイパスしてホストにマウントします。
2.ボリュームは異なるコンテナ間で共有および再利用できます。
3. ホスト ディスクと同じパフォーマンス。
4. ボリューム内のデータに対する操作はイメージ自体には影響しません。
5.ボリュームのライフサイクルは、コンテナのライフサイクルとは独立しています。コンテナが削除されても、ボリュームは存在し続けます。どのコンテナにも使用されていないボリュームは、Docker によって削除されません。
Docker はボリュームドライバー インターフェースを提供します。このインターフェースを実装することで、Docker コンテナにさまざまなボリューム ストレージ サポートを提供できます。現在、ローカル ボリューム ドライバーがデフォルトで実装されており、ホストのファイル システムを使用して Docker コンテナーにボリュームを提供します。

データ量を管理する2つの方法

Docker ボリュームの本質は、コンテナ内の特別なディレクトリです。コンテナーの作成プロセス中に、Docker はホスト上の指定されたディレクトリ (ボリューム ID で名前が付けられたディレクトリ、または指定されたホスト ディレクトリ) をコンテナー内の指定されたディレクトリにマウントします (bing マウント メソッドを使用)。そのため、マウントが完了した後のホスト ディレクトリとコンテナー内のターゲット ディレクトリは一致します。

1. バインドマウント

バインドマウントは、ホスト上のディレクトリまたはファイルをコンテナにマウントすることです。直感的で効率的に使用でき、理解しやすいです。
-vオプションを使用して、マウント パスを<host path>:<container path>形式で指定します。
#最初の部分はホストマシン上に実際に存在するパスです。2番目の部分はコンテナ内のパスです

nginxイメージを使用してコンテナをバックグラウンドで実行し、ホストの/dataディレクトリをコンテナのディレクトリ/usr/share/nginx/htmlにマウントします。[root@server1 ~]# docker run -d --name demo -v /data:/usr/share/nginx/html nginx 

ここに画像の説明を挿入

フォアグラウンドに切り替えて実行し、ホストとコンテナのそれぞれ指定されたディレクトリの内容を確認します。同じです。これは、このマウント方法が、通常使用するマウント方法と同じであるためです。元のデータは隠され、ホストマシンのデータに置き換えられます。
##Dockerのデフォルトのデータディレクトリは/dataなので、/dataディレクトリにはたくさんのものがあります

[root@server1 ~]# docker exec -it demo bash 

ここに画像の説明を挿入

バインドマウントのデフォルトの権限は読み取り/書き込み (rw) ですが、マウント時に読み取り専用 (ro) を指定できます。

-v オプションで指定されたパスが存在しない場合は、マウント時に自動的に作成されます。
docker run -it --name vm1 \ /etc/yum.repos.d/dvd.repo:/etc/yum.repos.d/dvd.repo:ro rhel7 bash

2. Docker管理ボリューム

バインドマウントではホストファイルシステムのパスを指定する必要があり、移植性が制限されます。
Docker 管理ボリュームではマウント ソースを指定する必要はなく、Docker はコンテナーのデータ ボリューム ディレクトリを自動的に作成します。作成されるデフォルトのデータ ボリューム ディレクトリはすべて /var/lib/docker/volumes にあります。
マウントがコンテナ内の既存のディレクトリを指している場合、コンテナ内の元のデータがボリュームにコピーされます。
ボリュームを作成する方法:

[root@server1 ~]# docker volume create webdata #webdataという名前のボリュームを作成します[root@server1 ~]# docker rm -f demo #上記で作成したボリュームを削除します[root@server1 ~]# docker run -d --name demo -v webdata:/usr/share/nginx/html nginx		
#コンテナ内の/usr/share/nginx/htmlディレクトリにwebdataボリュームをマウントし、コンテナを実行します

作成したWebデータボリュームをコンテナの/usr...ディレクトリにマウントします。
ここに画像の説明を挿入
Dockerがデフォルトで作成するデータボリュームのディレクトリに入り、ボリュームの中身を確認します。上ではボリュームが作成されているだけで、何も書き込まれていないことがわかります。ただし、ボリューム内の内容は、マウント時にコンテナ内の指定ディレクトリに何かあったため、それをコピーしたためです。
ここに画像の説明を挿入
コンテナを実行するために nginx イメージを使用します。アクセスに問題はありません。
ここに画像の説明を挿入
マウント時にマウント ソースが指定されていない場合、Docker は長いファイル名を持つランダムなボリュームを自動的に作成します。

[root@server1 ~]# docker rm -f デモ
[root@server1 ~]# docker run -d --name demo -v /usr/share/nginx/html nginx
67ab13a7b24c19c53f4ce117136b9d0e4dec93c615a0192ead919d10e6c2acae 

ここに画像の説明を挿入
ボリュームのソースディレクトリを表示するには、dockerinspectdemoコマンドを使用します。
ここに画像の説明を挿入
パスを取得したら、ディレクトリの内容を表示できます。

ls /var/lib/docker/volumes/2ca22fd769e4b7b6f5a02dd96fe8d47a6df5578074c0d340ced3ab33b25456ca/_data 

ここに画像の説明を挿入

バインドマウントとDocker管理ボリュームの比較

類似点: どちらもホスト ファイル システム内のパスです。
違いは図に示されています:
ここに画像の説明を挿入

これで、Docker でボリュームを管理する 2 つの方法についての説明は終了です。Docker ボリュームの詳細については、123WORDPRESS.COM の以前の記事を検索するか、次の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • Docker のコンテナ データ ボリュームの概要
  • Dockerボリューム削除操作
  • Dockerボリュームのファイルマッピング方法
  • Dockerボリュームマウントの実装方法
  • Docker データ ストレージ ボリュームの詳細な説明
  • Docker ボリュームの使用の詳細と例
  • Dockerはデータボリュームにデータを書き込む

<<:  MySQL における IF()、IFNULL()、NULLIF()、および ISNULL() 関数の使用に関する詳細な説明

>>:  リンクをクリックしたときに表示される点線のボックスを削除するいくつかの方法

推薦する

Zabbix 監視 Docker アプリケーション構成

コンテナの応用はますます一般的になっていますが、大量のコンテナをどのように管理すればよいのでしょうか...

CentOS 8にJenkinsをインストールする方法

CentOS 8 に Jenkins をインストールするには、root アカウントまたは sudo ...

スプライトとフォントアイコンを実装するためのCSS

スプライト:以前は、各画像リソースは独立した画像でした。ブラウザが Web サイト内のさまざまな W...

Dockerでデータディレクトリを移行する方法

目次ディスク使用量の表示ディスク クリーンアップ (軽々しく使用しないでください)データの移行ディス...

jQuery タグセレクターの適用例の詳細な説明

この記事では、jQueryタグセレクターアプリケーションの具体的なコードを例として紹介します。具体的...

Dockerfile を使用して Docker でイメージを構築する方法

イメージを構築するこれまで、テストやデモンストレーションにさまざまなイメージを使用しました。多くの場...

VMware マルチノード環境を構成する方法

このチュートリアルでは CentOS 7 64 ビットを使用します。各仮想マシンに 2GB のメモリ...

純粋な CSS で実装された大きなドロップダウン メニューのサンプル コード

これは純粋に CSS で実装された大きなドロップダウン メニューです。この大きなメニューは、js コ...

HTML におけるブロックコメントの使用に関する詳細な紹介

HTML の一般的なコメント: <!--XXXXXXXX--> (XXXXXXXX はコ...

背景とリンクとして画像を書き込む方法(背景画像+リンク)

写真を背景にしてリンクを記載します。たとえば、ウェブサイトのロゴ画像などです。例: ポテトのロゴ画像...

HTML thead タグの定義と使用法の詳細な紹介

コードをコピーコードは次のとおりです。 <thead> <!– 最初の 2 行をヘ...

マークアップ言語 - リスト

標準化されたデザインソリューション - マークアップ言語とスタイルマニュアルWeb 標準ソリューショ...

同期スクロールを実現するための複数のテーブル要素のサンプルコード

Element UIは、複数のテーブルを同時に水平および垂直にスクロールすることを実装します。 コー...

CSS 境界線の半分または部分的に表示される実装コード

1. 疑似クラスを使用して境界線の半分を表示する <!DOCTYPE html> <...

vue.config.js パッケージ最適化構成

Baiduの情報は多様すぎて目が回ります。心配しないでください。私はあなたのためにそれを体験しました...