溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

一起研究系列:容器-Docker Volume

發(fā)布時間:2020-07-12 22:23:04 來源:網(wǎng)絡 閱讀:415 作者:jxwpx 欄目:云計算

想要了解Docker Volume,首先我們需要知道Docker的文件系統(tǒng)是如何工作的。Docker鏡像是由多個文件系統(tǒng)(只讀層)疊加而成。當我們啟動一個容器的時候,Docker會加載只讀鏡像層并在其上(即鏡像棧頂部)添加一個讀寫層。如果運行中的容器修改了現(xiàn)有的一個已經(jīng)存在的文件,那該文件將會從讀寫層下面的只讀層復制到讀寫層,該文件的只讀版本仍然存在,只是已經(jīng)被讀寫層中該文件的副本所隱藏。當刪除Docker容器,并通過該鏡像重新啟動時,之前的更改將會丟失。在Docker中,只讀層及在頂部的讀寫層的組合被稱為Union File System(聯(lián)合文件系統(tǒng))。

為了能夠保存(持久化)數(shù)據(jù)以及共享容器間的數(shù)據(jù),Docker提出了Volume的概念。簡單來說,Volume就是目錄或者文件,它可以繞過默認的聯(lián)合文件系統(tǒng),而以正常的文件或者目錄的形式存在于宿主機上。

總結:Volume可以將容器以及容器產生的數(shù)據(jù)分離開來,當你使用docker? rm? my_container刪除容器時,不會影響相關的數(shù)據(jù)。

我們可以通過兩種方式來初始化Volume,這兩種方式有些細小而又重要的差別。我們可以在運行時使用-v來聲明Volume:

docker管理數(shù)據(jù)的方式有兩種:

· 數(shù)據(jù)卷(Data Volumes)

· 數(shù)據(jù)卷容器(Data Volumes Containers)

數(shù)據(jù)卷:

數(shù)據(jù)卷是為一個或多個容器專門指定繞過Union File System的目錄,位于容器中,可將宿主機的目錄掛載到數(shù)據(jù)卷上,對數(shù)據(jù)卷的修改操作立刻可見,并且更新數(shù)據(jù)不會影響鏡像,從而實現(xiàn)數(shù)據(jù)在宿主機與容器之間的遷移,為持續(xù)性或共享數(shù)據(jù)提供一些有用的功能,數(shù)據(jù)卷的使用,類似于Linux下對目錄進行的mount操作

· 數(shù)據(jù)卷可以在容器間共享和重用

· 數(shù)據(jù)卷數(shù)據(jù)改變是直接修改的

· 數(shù)據(jù)卷數(shù)據(jù)改變不會被包括在容器中

· 數(shù)據(jù)卷是持續(xù)性的,直到?jīng)]有容器使用它

1、創(chuàng)建數(shù)據(jù)卷

在docker run 命令中使用-v選項可以在容器中創(chuàng)建數(shù)據(jù)卷。多次使用-v選項可以創(chuàng)建多個數(shù)據(jù)卷。例如:

[root@docker01 ~]# docker run -itd -v /data1 -v /date2 --name web003 centos:httpv1

90030942574d6b47b6be2922a86b38f7483956f6231ab5e30fccc9d4431f61ec

進入容器web003,可以看到兩個數(shù)據(jù)卷已經(jīng)創(chuàng)建成功并分別掛載到/data1與/date2上

一起研究系列:容器-Docker Volume

可以使用docker inspect web003查看到掛載的數(shù)據(jù)卷

[root@docker01 ~]# docker inspect web003

一起研究系列:容器-Docker Volume

用戶也可以在Dockerfile中指定數(shù)據(jù)卷:

例如:

FROM debian:wheezy

VOLUME? /data

注1:Docker 掛載數(shù)據(jù)卷的默認權限是讀寫,用戶也可以通過 :ro 指定為只讀。

例如:

一起研究系列:容器-Docker Volume

2、掛載主機目錄作為數(shù)據(jù)卷

如果想在容器中使用主機上的某個目錄,你可以通過-v參數(shù)來指定(注:注意冒號前面的和后面的內容):

docker run -v /host/path:/some/path ...

這明確地告訴Docker使用指定的主機路徑來代替Docker自己創(chuàng)建的根路徑并掛載到容器內指定的路徑(以上例子為/some/path)。需要注意的是,宿主機本地目錄上的路徑必須使用絕對路徑,如果主機上的路徑不存在,目錄將自動在給定的路徑中創(chuàng)建。

在用 docker run 命令的時候,可以指定掛載一個本地主機的目錄到容器中去,可以使用多次-v選項為一個 docker 容器運行掛載多個本地主機目錄。

實例:

1、在宿主機上創(chuàng)建/web/webapp1目錄,并創(chuàng)建一個index.html文件,內容如下:

[root@docker01 ~]# mkdir /web/webapp1 -p

[root@docker01 ~]# cd /web/webapp1/

[root@docker01 webapp1]# echo "<h2> hello world</h2>" >> index.html

[root@docker01 webapp1]# cat index.html

<h2> hello world</h2>

[root@docker01 webapp1]#

2、使用帶有apache服務的一個鏡像,生成容器

[root@docker01 ~]# docker run -itd -v /web/webapp1/:/var/www/html/ -p 8000:80 --name web005 centos:httpv1

一起研究系列:容器-Docker Volume

3、訪問容器的網(wǎng)站服務:

一起研究系列:容器-Docker Volume

上面的命令加載主機的 /web/webapp1 目錄到容器的 /var/www/html 目錄。這個功能在進行測試的時候十分方便,比如用戶可以放置一些程序到本地目錄中,來查看容器是否正常工作。本地目錄的路徑必須是絕對路徑,如果目錄不存在 Docker 會自動為你創(chuàng)建它。/web/webapp1目錄的文件都將會出現(xiàn)在容器內。這對于在主機和容器之間共享文件是非常有幫助的,例如掛載需要編譯的源代碼。為了保證可移植性(并不是所有的系統(tǒng)的主機目錄都是可以用的),掛載主機目錄不需要從Dockerfile指定。

數(shù)據(jù)卷容器:

如果需要在容器之間共享一些數(shù)據(jù),最簡單的方法就是使用數(shù)據(jù)卷容器。數(shù)據(jù)卷容器就是一個普通的容器,專門提供數(shù)據(jù)卷給其它容器掛載使用。

使用方法如下:首先,需要創(chuàng)建一個容器作為數(shù)據(jù)卷容器,之后在其它容器創(chuàng)建時用--volumes-from掛載數(shù)據(jù)卷容器中的數(shù)據(jù)卷使用。

常見的使用場景是使用純數(shù)據(jù)卷容器來持久化數(shù)據(jù)庫、配置文件或者數(shù)據(jù)文件等。

例如:

docker run --name dbdata postgres echo "Data-only container for postgres"

該命令將會使用一個已經(jīng)包含在Dockerfile里定義過Volume的postgres鏡像來生成一個容器dbdata(如:VOLUME? /var/lib/postgresql/data),運行echo命令然后退出。當我們運行docker? ps命令時,echo可以幫助我們識別某鏡像的用途。我們可以用--volumes-from命令來識別其它容器的Volume:

docker run -d --volumes-from dbdata --name db1 postgres

實例:

現(xiàn)在就來創(chuàng)建一個命名的數(shù)據(jù)卷容器:

#docker run -dit -v /test --name data 鏡像

一起研究系列:容器-Docker Volume

使用--volumes-from選項在另一個容器中掛載/test卷。不管data容器是否運行,其它容器都可以掛載該容器數(shù)據(jù)卷,當然如果只是單獨的數(shù)據(jù)卷是沒必要運行容器的。

然后,你可以在其他容器中使用 --volumes-from 來掛載/test卷

#docker run -dit --volumes-from data --name test1 鏡像

一起研究系列:容器-Docker Volume

再添加一個容器:

一起研究系列:容器-Docker Volume

注:還可以使用多個 --volumes-from 參數(shù)來從多個容器掛載多個數(shù)據(jù)卷

執(zhí)行docker ps查看

一起研究系列:容器-Docker Volume

進入test1、test2容器,執(zhí)行df查看

一起研究系列:容器-Docker Volume

也可以繼承其它掛載有 /test 卷的容器

#docker run -dit --volumes-from test1 --name test3 鏡像

如果刪除了掛載的容器(包括 data、db1 和 db2),數(shù)據(jù)卷并不會被自動刪除。如果要刪除一個數(shù)據(jù)卷,必須在刪除最后一個還掛載著它的容器時使用? docker rm -v? 命令來指定同時刪除關聯(lián)的容器。

利用 Data Volume Container來備份、恢復、移動數(shù)據(jù)

備份

數(shù)據(jù)卷另外一個功能是使用他們來備份、恢復、移動數(shù)據(jù),如果你在用數(shù)據(jù)容器,那做備份是相當容易的。使用 --volume 標記來創(chuàng)建一個加載了卷的新的容器,命令如下:

該示例應該會將Volume里所有的東西壓縮為一個tar包

[root@docker01 ~]# docker run --rm --volumes-from data -v $(pwd):/backup centos:httpv1 tar cvf /backup/backup.tar /test

一起研究系列:容器-Docker Volume

這里我們創(chuàng)建了一個容器,先從data容器來掛載數(shù)據(jù)卷。然后從本地主機掛載當前目錄到容器的 /backup 目錄。最后,使用tar命令來將data 卷備份為backup.tar 。當命令執(zhí)行完、容器停止之后,我們就備份了 data 數(shù)據(jù)卷

執(zhí)行完成之后刪除容器 --rm,此時備份就在當前的目錄下,名為backup.tar

宿主機當前目錄下產生了test卷的備份文件test.tar

一起研究系列:容器-Docker Volume

一起研究系列:容器-Docker Volume

恢復

一起研究系列:容器-Docker Volume

附:

權限與許可

通常你需要設置Volume的權限或者為Volume初始化一些默認數(shù)據(jù)或者配置文件。要注意的關鍵點是,在Dockerfile的VOLUME指令后的任何指令都不能改變該Volume,比如:

FROM debian:wheezy

RUN useradd foo

VOLUME /data

RUN touch /data/x

RUN chown -R foo:foo /data

該Docker file不能按預期那樣運行,我們本來希望touch命令在鏡像的文件系統(tǒng)上運行,但是實際上它是在一個臨時容器的Volume上運行。如下所示:

FROM debian:wheezy

RUN useradd foo

RUN mkdir /data && touch /data/x

RUN chown -R foo:foo /data

VOLUME /data

所以,牢記Dockerfile中VOLUME指令的位置(VOLUME是設置指令)

如果你沒有通過RUN指令設置權限,那么你就需要在容器啟動時使用CMD或ENTRYPOINT指令來執(zhí)行

刪除 Volumes

Volume 只有在下列情況下才能被刪除:

· docker rm -v刪除容器時添加了-v選項

例如:你可以告訴Docker同時刪除容器和其Volume:

????? docker rm -v my_container

· docker run --rm運行容器時添加了--rm選項

即使用以上兩種命令,也只能刪除沒有容器連接的Volume。連接到用戶指定主機目錄的Volume永遠不會被docker刪除。否則,會在/var/lib/docker/volumes目錄下得到一些僵尸文件和目錄,并且還不容易說出它們到底代表什么。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內容。

AI