Dockerコンテナのデータボリュームの詳細な説明

Dockerコンテナのデータボリュームの詳細な説明

何ですか

まず、Docker の概念を見てみましょう。

アプリケーションと実行環境をコンテナにパッケージ化します。実行はコンテナに付随して行われますが、データが永続化され、コンテナ間でデータを共有できることが期待されます。

Docker コンテナによって生成されたデータが、docker commit を通じて新しいイメージを生成してイメージの一部として保存されていない場合、コンテナが削除されると、データは自然に消えてしまいます。

Docker にデータを保存するにはボリュームを使用します。

一言で言えば、RedisのRDBとAOFに似ています。

私に何ができる?

ボリュームは、1 つ以上のコンテナーに存在し、Docker によってコンテナーにマウントされるが、Union File System に属していないディレクトリまたはファイルです。そのため、Union FileSystem をバイパスして、永続ストレージまたは共有データにいくつかの機能を提供できます。

ボリュームの設計目的はデータの永続性であり、コンテナのライフサイクルとは完全に独立しています。そのため、コンテナが削除されても、Docker はマウントされたデータ ボリュームを削除しません。

特徴:

  • データボリュームはコンテナ間でデータを共有または再利用するために使用できます
  • 音量の変更は直接影響します
  • データ量の変更はイメージ更新には含まれません
  • データ ボリューム コンテナのライフサイクルは、コンテナがそれを使用しなくなるまで続きます (--volumes from)

要約:

  • コンテナデータの永続性
  • 継承 + コンテナ間のデータ共有

データ量

直接コマンドの追加

docker run -it -v /host 絶対パス ディレクトリ:/コンテナ ディレクトリ イメージ名docker run -it -v /host 絶対パス ディレクトリ:/コンテナ ディレクトリ:ro イメージ名//コマンドでアクセス権を指定、ro: 読み取り専用

データボリュームが正常にマウントされているかどうかを確認します。

docker コンテナ ID を検査する

DockerFileを使用して追加する

ルートディレクトリに新しいmydockerフォルダを作成し、次のように入力します。

Dockerfile で VOLUME 命令を使用して、イメージに 1 つ以上のデータ ボリュームを追加できます。

DockerFileビルド

DockerFile の記述については、Tomcat などの DockerHub にある各イメージの DockerFile ファイルを参照できます: https://github.com/docker-library/tomcat/blob/300ac03f4696c761a81fa10afbb893f3368061de/8.5/jdk8/openjdk-buster/Dockerfile

#ボリュームテスト
Centosより
ボリューム ["/dataVolumeContainer1","/dataVolumeContainer2"]
CMD エコー "終了しました、-------成功1"
コマンド /bin/bash

ビルド後にイメージを生成する

新しいイメージ zzyy/centos を取得する

コンテナを実行する

上記の手順により、コンテナ内のボリュームディレクトリアドレスはすでにわかっており、対応するホストディレクトリはどこにあるか

述べる:

Docker はホスト ディレクトリをマウントします。Docker アクセスではディレクトリを開けません、権限が拒否されました

解決策: ディレクトリをマウントした後、--privileged=trueパラメータを追加します。

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

何ですか

名前付きコンテナがデータボリュームをマウントし、他のコンテナはこれ(親コンテナ)をマウントすることでデータを共有します。データボリュームをマウントするコンテナをデータボリュームコンテナと呼びます。

コンテナ間の推移的な共有 (--volumes-from)

docker run -it --name dco2 --volumes-from dc01 zzyy/cenos // dc01 は最初に作成されたコンテナで、dco2 はデータ共有を実現するために dc01 を継承します。

データ ボリュームは親コンテナ (dc01) によってマウントされます。dc01 が dc02 と dc03 にマウントされ、その後削除された場合でも、データ ボリュームは有効なままです。

構成情報はコンテナ間で転送され、コンテナが使用しなくなるまでデータ ボリュームのライフ サイクルは継続されます。

要約する

Docker コンテナのデータボリュームに関する記事はこれで終わりです。Docker コンテナのデータボリュームについての詳細は、123WORDPRESS.COM の過去の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • Docker データボリュームとデータコンテナの詳細な紹介と例
  • Dockerデータボリューム、データボリュームコンテナの詳細な紹介
  • Docker のコンテナ データ ボリュームの概要
  • Docker コンテナ データ ボリュームの名前付きマウントと匿名マウントの問題
  • Dockerでボリュームを管理する2つの方法
  • Docker データボリュームの一般的な操作コードの例
  • Dockerコンテナデータボリュームのマウントの簡単な概要
  • DockerはMySQLデータを保存するためにボリュームをマウントします

<<:  Navicat Premium が MySQL 8.0 に接続してエラー「1251」を報告する問題を解決する方法の分析

>>:  入力ボックスのコンテンツプロンプトと非表示機能を実装する JavaScript

推薦する

Hタグはウェブページ制作において適切に使用すべきである

HTML タグには、ページのタイトルを処理するための特別なタグがあります。これらは h1、h2、h3...

JavaScriptにおけるこのポインティング問題の詳細な説明

序文JS の this ポインターは、初心者にとって常に頭痛の種でした。今日は、これが地面に落ちたと...

HTMLテーブルではテーブルの外側の境界線のみが表示されます

質問があります。Dreamweaver で、3 行 1 列のログイン フォーム (ログイン、登録、パ...

RedisとMySQLの違いを簡単に説明してください

MySQL はディスクに保存される永続的なストレージであり、取得には一定の IO が伴うことはご存じ...

Linux で Bash コマンド プロンプトをカスタマイズする方法

序文ご存知のとおり、bash (Bourne-Gain Shell) は、ほとんどの Linux デ...

Vue2.xは、ユーザーのログインと終了を実装するためにルーティングナビゲーションガードを設定します。

目次序文1. ルーティングナビゲーションガードを設定する1. グローバルナビゲーションガード2. ロ...

ウェブサイトに最も必要なのは、ターゲットユーザーグループのエクスペリエンスを向上させることです。

「大河は東に流れ、波は歴代の英雄たちを洗い流した。古城の西側は三国時代の周朗の赤壁だと言われている...

Docker を使用した JMeter+Grafana+Influxdb 監視プラットフォームの構築に関する詳細なチュートリアル

Jmeter がネイティブの結果表示機能を提供していることは誰もが知っています。ネイティブの結果表示...

Linux で MySQL スケジュールタスクを実装する方法

前提: ストアド プロシージャは、毎日午後 10 時から午前 5 時まで 10 分ごとに実行されます...

CentOS7でXShellとネットワーク設定を接続する方法

1. Linuxネットワーク構成ネットワークを構成する前に、まずローカル IPv4 アドレスやデフォ...

Vueが学生管理機能を実装

この記事では、学生管理を実装するためのVueの具体的なコードを例として紹介します。具体的な内容は次の...

Linux でディスクをマウントし、起動時に自動的にマウントするように設定する方法

皆さんの時間は貴重だと承知しているので、プロセス コマンドを直接書き留めておきます。設定できます。原...

MySQLデータクエリが多すぎるとOOMが発生するかどうかについての簡単な議論

目次サーバー層でのフルテーブルスキャンの影響InnoDB におけるフルテーブルスキャンの影響Inno...

Vue3 コンパイルプロセス - ソースコード分析

序文: Vue3 がリリースされてからかなり経ちますが、最近、会社のプロジェクトでVue3 + Ty...

Docker Hubの動作原理と実装プロセスの分析

GitHub が提供するコード ホスティング サービスと同様に、Docker Hub はイメージ ホ...