詳解docker進行數(shù)據(jù)掛載的三種模式
Docker 提供了三種方式將數(shù)據(jù)從宿主機掛載到 Docker容器中: volumes、bind mounts、tmpfs 。
Volumes是在宿主機文件系統(tǒng)的一個路徑,默認(rèn)情況下統(tǒng)一的父路徑是 /var/lib/docker/volumes/
,非 Docker 進程不能修改這個路徑下面的文件,所以說 Volumes 是容器數(shù)據(jù)持久存儲數(shù)據(jù)最安全的一種方式。Bind mounts 可以將文件存儲在宿主機文件系統(tǒng)的任何路徑,所以非 Docker進程也可以對其進行修改,存在潛在的安全風(fēng)險。Tmpfs 只存儲在宿主機的內(nèi)存中,不會寫入到宿主機文件系統(tǒng)中,不會持久化存儲。
本文我們先來介紹其中的兩種:Bind mounts與Tmpfs。Volumes 由于相對重要,會單獨起一個文章進行說明。
一、Tmpfs掛載
需要再次強調(diào)的是tmpfs
掛載是臨時的,只存留在容器宿主機的內(nèi)存中。當(dāng)容器停止時,tmpfs
掛載文件路徑將被刪除,在那里寫入的文件不會被持久化。
docker run -d \ -p 8888:8888 \ --tmpfs /tmp \ --name spboot zimug/docker-test:1
學(xué)過SpringBoot的同學(xué)可能都知道,SpringBoot項目啟動之后會在/tmp目錄下面解壓出tomcat容器,提供web服務(wù)。
所以將/tmp
目錄使用tmpfs方式掛載到宿主機的內(nèi)存中,不僅場景合適,也會提升springboot項目的運行效率(內(nèi)存操作)。
二、Bind mounts
其實Bind Mounts掛載數(shù)據(jù)卷的方式也是大家最常見的一種方式,比如使用-v
參數(shù)綁定數(shù)據(jù)卷,其中/root/nginx/html
是我們?nèi)我庵付ǖ囊粋€宿主機磁盤文件目錄,這種情況下就是Bind mounts方式掛載數(shù)據(jù)卷。
-v /root/nginx/html:/usr/share/nginx/html/
除了使用-v
參數(shù)綁定的方式,還可以使用--mount
參數(shù)綁定的方式實現(xiàn)Bind mounts數(shù)據(jù)卷掛載。在--mount
參數(shù)綁定的方式之前,我們先創(chuàng)建一個宿主機文件路徑mkdir -p /root/nginx/html
用于做實驗 。
docker run -d --name bind-mount-nginx \ -p 80:80 \ --mount type=bind,source=/root/nginx/html,target=/usr/share/nginx/html/,readonly \ nginx:latest
--mount
以鍵值對的方式傳參,比-v
提供了更多的選項
type=bind
表示以Bind mounts方式掛載數(shù)據(jù)卷source=/root/nginx/html
表示宿主機的文件路徑target=/usr/share/nginx/html/
表示容器的文件路徑,宿主機source文件路徑掛載到容器的target路徑readonly配置參數(shù),表示文件路徑采用只讀的方式掛載
三、Bind mounts-測試是否正確掛載數(shù)據(jù)卷
在宿主機 /root/nginx/html
目錄下新建一個index.html
,文件內(nèi)容如下
<!DOCTYPE html> <html> <body> <h1>Bind mounts</h1> </body> </html>
訪問容器宿主機服務(wù)器80端口得到如下的響應(yīng)結(jié)果,證明數(shù)據(jù)卷掛載成功了。
四、Bind mounts-驗證只讀掛載
在--mount
中加入一個readonly配置參數(shù),表示文件路徑采用只讀的方式掛載。即:該路徑下的文件可以在宿主機上進行修改,但是容器內(nèi)的應(yīng)用程序不能修改該文件。
--mount type=bind,source=/root/nginx/html,target=/usr/share/nginx/html/,readonly
可以通過docker inspect <容器ID或容器名稱>
查看數(shù)據(jù)卷的掛載結(jié)果,如下
"Mounts": [
{
"Type": "bind",
"Source": "/root/nginx/html",
"Destination": "/usr/share/nginx/html",
"Mode": "",
"RW": false,
"Propagation": "rprivate"
}
],
- 數(shù)據(jù)卷掛載類型是bind(mount bind)
- 宿主機源路徑
/root/nginx/html
,容器掛載目標(biāo)路徑/usr/share/nginx/html
"RW": false
表示只讀模式,路徑內(nèi)文件不能被容器內(nèi)程序修改
大家可以通過docker exec -it <容器ID或容器名稱> /bin/bash
進入容器內(nèi)部嘗試修改/usr/share/nginx/html
路徑下的文件,看看能不能修改,相信經(jīng)過你的驗證答案一定是否定的。
到此這篇關(guān)于docker進行數(shù)據(jù)掛載的三種模式的文章就介紹到這了,更多相關(guān)docker數(shù)據(jù)掛載內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
docker?swarm快速部署redis分布式集群的詳細(xì)過程
這篇文章主要介紹了docker?swarm快速部署redis分布式集群,只需要通過docker-compose.yml文件和一個啟動命令就完成redis分布式部署的方式,讓其分別部署在不同機器上,并實現(xiàn)集群搭建,需要的朋友可以參考下2022-10-10docker-compose up -d和docker-compose up -
本文主要介紹了docker-compose up -d和docker-compose up --build的區(qū)別,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-07-07docker搭建redis哨兵集群并且整合springboot的實現(xiàn)
本文主要介紹了docker搭建redis哨兵集群并且整合springboot的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-07-07解決docker run 或者 docker restart 啟動鏡像就自動退出
這篇文章主要介紹了解決docker run 或者 docker restart 啟動鏡像就自動退出的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-11-11Docker跨主機網(wǎng)絡(luò)(overlay)的實現(xiàn)
這篇文章主要介紹了Docker跨主機網(wǎng)絡(luò)(overlay)的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-12-12