Docker系列教程14-Docker資料持久化
容器中資料持久化主要有兩種方式:
- 資料卷(Data Volumes)
- 資料卷容器(Data Volumes Dontainers)
資料卷
資料卷是一個可供一個或多個容器使用的特殊目錄,可以繞過UFS(Unix File System)。
- 資料卷可以在容器之間共享和重用
- 對資料卷的修改會立馬生效
- 對資料卷的更新,不會影響映象
- 資料卷預設會一直存在,即使容器被刪除
- 一個容器可以掛載多個資料卷
注意:資料卷的使用,類似於 Linux 下對目錄或檔案進行 mount。
建立資料卷
示例:
docker run --name nginx-data -v /mydir nginx
執行如下命令即可檢視容器構造的詳情:
docker inspect 容器ID
由測試可知:
- Docker會自動生成一個目錄作為掛載的目錄。
- 即使容器被刪除,宿主機中的目錄也不會被刪除。
刪除資料卷
資料卷是被設計來持久化資料的,因此,刪除容器並不會刪除資料卷。如果想要在刪除容器時同時刪除資料卷,可使用如下命令:
docker rm -v 容器ID
這樣既可在刪除容器的同時也將資料卷刪除。
掛載宿主機目錄作為資料卷
docker run --name nginx-data2 -v /host-dir:/container-dir nginx
這樣既可將宿主機的/host-dir路徑載入到容器的/container-dir中。
需要注意的是:
- 宿主機路徑儘量設定絕對路徑——如果使用相對路徑會怎樣?
- 測試給答案
- 如果宿主機路徑不存在,Docker會自動建立
TIPS
Dockerfile暫時不支援這種形式。
掛載宿主機檔案作為資料卷
docker run --name nginx-data3 -v /檔案路徑:/container路徑 nginx
指定許可權
預設情況下,掛載的許可權是讀寫許可權。也可使用:ro
引數指定只讀許可權。
示例:
docker run --name nginx-data4 -v /host-dir:/container-dir:ro nginx
這樣,在容器中就只能讀取/container-dir中的檔案,而不能修改了。
資料卷容器
如果有資料需要在多個容器之間共享,此時可考慮使用資料卷容器。
建立資料卷容器:
docker run --name nginx-volume -v /data nginx
在其他容器中使用-volumes-from
來掛載nginx-volume容器中的資料卷。
docker run --name v1 --volumes-from nginx-volume nginx
docker run --name v2 --volumes-from nginx-volume nginx
這樣:
- v1、v2兩個容器即可共享nginx-volume這個容器中的檔案。
- 即使nginx-volume停止,也不會有任何影響。
相關文章
- Docker資料持久化Docker持久化
- Docker之 資料持久化Docker持久化
- Docker最全教程——資料庫容器化之持久儲存資料(十一)Docker資料庫
- Docker --volume-資料持久化Docker持久化
- rabbitmq 如何在 docker 下做資料持久化?MQDocker持久化
- Docker 持久化Docker持久化
- 1.05 docker的持久化儲存和資料共享Docker持久化
- Docker的持久化儲存和資料共享(四)Docker持久化
- Redis資料持久化—RDB持久化與AOF持久化Redis持久化
- Redis系列2:資料持久化提高可用性Redis持久化
- Redis 資料持久化Redis持久化
- fabric資料持久化持久化
- redis系列:RDB持久化與AOF持久化Redis持久化
- Spring Cloud Alibaba基礎教程:Nacos的資料持久化SpringCloud持久化
- 基於Docker部署Oracle、MySQL等資料庫的資料檔案持久化DockerOracleMySql資料庫持久化
- Docker最全教程——資料庫容器化(十)Docker資料庫
- 【Flutter 3-4】Flutter進階教程——資料持久化sqflFlutter持久化
- 【Unity】資料持久化PlayerPrefsUnity持久化
- Redis的資料持久化Redis持久化
- Docker下Nacos持久化配置Docker持久化
- 資料的序列化&持久化持久化
- 從0到1使用Kubernetes系列(六):資料持久化實戰持久化
- 鴻蒙資料持久化sqlite鴻蒙持久化SQLite
- 可持久化資料結構持久化資料結構
- 詳解 ZooKeeper 資料持久化持久化
- iOS資料持久化設計iOS持久化
- DelayQueue系列(三):持久化方案持久化
- docker系列(四):資料卷Docker
- 可持久化資料結構1持久化資料結構
- Milvus 2.0 資料插入與持久化持久化
- Kubernetes 持久化資料儲存 StorageClass持久化
- iOS資料持久化儲存-CoreDataiOS持久化
- HarmonyOS資料管理與應用資料持久化(一)持久化
- [Docker 系列]docker 學習六,資料卷容器Docker
- [Docker 系列]docker 學習 五,容器資料卷Docker
- 鴻蒙首選項資料持久化鴻蒙持久化
- redis原始碼分析(五):資料持久化Redis原始碼持久化
- Docker下redis的主從、持久化配置DockerRedis持久化