Docker數(shù)據(jù)存儲總結
閱讀本文前,希望你已經(jīng)對Volumes,Bind mounts和tmpfs mounts有了初步的了解,具體可以參考以下文章:
下圖展示了Volumes,Bind mounts和tmpfs mounts三種存儲技術的不同:

Volumes的使用場景
- 在多個容器間共享數(shù)據(jù)。
- 無法確保Docker主機一定擁有某個指定的文件夾或目錄結構,使用Volumes可以屏蔽這些宿主機差異。
- 當你希望將數(shù)據(jù)存儲在遠程主機或云提供商上。
- 當你希望備份,恢復或者遷移數(shù)據(jù)從一臺Docker主機到另一臺Docker主機,Volumes是更好的選擇。
Bind mounts的使用場景
- 在宿主機和容器間共享配置文件。例如將nginx容器的配置文件保存在宿主機上,通過Bind mounts掛載后就不用進入容器來修改nginx的配置了。
- 在宿主機和容器間共享代碼或者build輸出。例如將宿主機某個項目的target目錄掛載到容器中,這樣在宿主機上Maven build出一個最新的產(chǎn)品,可以直接咋i容器中運行,而不用生成一個新的鏡像。
- Docker主機上的文件或目錄結構是確定的
tmpfs mounts的使用場景
- 當你因為安全或其他原因,不希望將數(shù)據(jù)持久化到容器或宿主機上,那你可以使用tmpfs mounts模式。
Bind mounts和Volumes行為上的差異
- 如果你將一個空Volume掛載到一個非空容器目錄上,那么這個容器目錄中的文件會被復制到Volume中,即容器目錄原有文件不會被Volume覆蓋。
- 如果你使用Bind mounts將一個宿主機目錄掛載到容器目錄上,此容器目錄中原有的文件會被隱藏,從而只能讀取到宿主機目錄下的文件。
參考文章
https://docs.docker.com/storage/#good-use-cases-for-tmpfs-mounts
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。如果你想了解更多相關內容請查看下面相關鏈接
相關文章
如何使用 docker compose 搭建 fastDFS文件服務器
這篇文章主要介紹了如何使用 docker compose 搭建 fastDFS文件服務器,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-10-10
本地Docker安裝Postgres 12 + pgadmin的方法 (支持Apple M1)
這篇文章主要介紹了本地Docker安裝Postgres 12 + pgadmin的方法 (支持Apple M1),本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-03-03
利用 Docker 構建簡單的 java 開發(fā)編譯環(huán)境的方法詳解
這篇文章主要介紹了利用 Docker 構建簡單的 java 開發(fā)編譯環(huán)境的相關知識,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-11-11

