前回の記事では、Dockerの基礎知識であるローカルディレクトリのマウント方法を紹介しました。今日は、Dockerでデータボリュームを管理する2つの方法を紹介します。具体的な内容は以下のとおりです。 データボリュームとはデータ量:ボリュームとは、1 つ以上のコンテナー内に存在する特定のファイルまたはフォルダーです。このディレクトリは、ユニオン ファイル システムから独立した形式でホスト マシン内に存在し、データの共有と永続化を容易にします。 データ ボリュームを使用する理由は何ですか? Docker 階層化ファイルシステムの問題: データ量を管理する2つの方法
1. バインドマウントバインドマウントは、ホスト上のディレクトリまたはファイルをコンテナにマウントすることです。直感的で効率的に使用でき、理解しやすいです。 nginxイメージを使用してコンテナをバックグラウンドで実行し、ホストの/dataディレクトリをコンテナのディレクトリ/usr/share/nginx/htmlにマウントします。[root@server1 ~]# docker run -d --name demo -v /data:/usr/share/nginx/html nginx フォアグラウンドに切り替えて実行し、ホストとコンテナのそれぞれ指定されたディレクトリの内容を確認します。同じです。これは、このマウント方法が、通常使用するマウント方法と同じであるためです。元のデータは隠され、ホストマシンのデータに置き換えられます。 [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管理ボリュームバインドマウントではホストファイルシステムのパスを指定する必要があり、移植性が制限されます。 [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...ディレクトリにマウントします。 [root@server1 ~]# docker rm -f デモ [root@server1 ~]# docker run -d --name demo -v /usr/share/nginx/html nginx 67ab13a7b24c19c53f4ce117136b9d0e4dec93c615a0192ead919d10e6c2acae
ls /var/lib/docker/volumes/2ca22fd769e4b7b6f5a02dd96fe8d47a6df5578074c0d340ced3ab33b25456ca/_data バインドマウントとDocker管理ボリュームの比較 類似点: どちらもホスト ファイル システム内のパスです。 これで、Docker でボリュームを管理する 2 つの方法についての説明は終了です。Docker ボリュームの詳細については、123WORDPRESS.COM の以前の記事を検索するか、次の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。 以下もご興味があるかもしれません:
|
<<: MySQL における IF()、IFNULL()、NULLIF()、および ISNULL() 関数の使用に関する詳細な説明
>>: リンクをクリックしたときに表示される点線のボックスを削除するいくつかの方法
目次1. ミニプログラム下請け2. Uniapp 下請けアプレット下請けの手順: 1. manife...
MySQLはインストール時に設定できますが、それより低いバージョンは設定できないようで、インストール...
この記事では、ウォーターフォールフローが底に達したときにデータを動的にロードするためのjsの具体的な...
序文MySQL と Navicat をインストールした後、接続時に、ERROR 2059 (HY00...
実際の使用では、ミニプログラムを友人や友人サークルと共有する必要があることが多く、通常は一度に 1 ...
序文「データベース トランザクションの特徴は何ですか?」と尋ねられたら、 ACID 特性である原子性...
[LeetCode] 182.重複メールPerson という名前のテーブル内のすべての重複メールを...
仮想マシンソフトウェア: VMware Workstationイメージ: deepin-deskto...
Canal は、Java を使用して開発された Alibaba のオープンソース プロジェクトです...
<TD> タグの属性は、テーブル内のセルのプロパティを設定するために使用されます。表 &...
データ分析会社Net Market Shareによると、Linuxデスクトップオペレーティングシステ...
1.Tomcatの最適化構成(1)Tomcatのcatalina.batを変更するJavaをサーバー...
この記事では、MySQL の左結合における on 条件と where 条件の使用法の違いを例を使って...
目次1. はじめに:この場合、通常は 2 つのアプローチがあります。 2. CancelToken ...
目次react-beautiful-dndを選ぶ理由基本的な使い方基本概念使い方使用中に発生した問題...