2.數據卷容器(Data Volume Containers):使用特定容器維護數據卷。如何使用數據卷容器在容器和主機、容器和容器之間共享數據,并實現數據的備份和恢復。

數據卷

數據卷是一個可供容器使用的特殊目錄,它將主機操作系統目錄直接映射進容器,類似于Linux中的mount操作。

數據卷可以提供很多有用的特性,如下所示:

1.數據卷可以在容器之間共享和重用,容器間傳遞數據將變得高效方便;
2.對數據卷內數據的修改會立馬生效,無論是容器內操作還是本地操作;
3.對數據卷的更新不會影響鏡像,解耦了應用和數據;
4.卷會一直存在,直到沒有容器使用,可以安全地卸載它。

1.在容器內創建一個數據卷

在用docker run命令的時候,使用-v標記可以在容器內創建一個數據卷。多次重復使用-v標記可以創建多個數據卷。

下面使用training/webapp鏡像創建一個web容器,并創建一個數據卷掛載到容器的/webapp目錄:

$ docker run -d -P --name web -v /webapp training/webapp python app.py

-P是將容器服務暴露的端口,是自動映射到本地主機的臨時端口。

2.掛載一個主機目錄作為數據卷

使用-v標記也可以指定掛載一個本地的已有目錄到容器中去作為數據卷(推薦方式)。

$ docker run -d -P --name web -v /src/webapp:/opt/webapp training/webapp python app.py

上面的命令加載主機的/src/webapp目錄到容器的/opt/webapp目錄。

這個功能在進行測試的時候十分方便,比如用戶可以將一些程序或數據放到本地目錄中,然后在容器內運行和使用。另外,本地目錄的路徑必須是絕對路徑,如果目錄不存在,Docker會自動創建。

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

$ docker run -d -P --name web -v /src/webapp:/opt/webapp:ro training/webapp python app.py

加了:ro之后,容器內對所掛載數據卷內的數據就無法修改了。

3.掛載一個本地主機文件作為數據卷

-v標記也可以從主機掛載單個文件到容器中作為數據卷(不推薦)。

$ docker run --rm -it -v ~/.bash_history:/.bash_history ubuntu /bin/bash

這樣就可以記錄在容器輸入過的命令歷史了。

如果直接掛載一個文件到容器,使用文件編輯工具,包括vi或者sed–in-place的時候,可能會造成文件inode的改變,從Docker 1.1.0起,這會導致報錯誤信息。所以推薦的方式是直接掛載文件所在的目錄。

數據卷容器

如果用戶需要在多個容器之間共享一些持續更新的數據,最簡單的方式是使用數據卷容器。數據卷容器也是一個容器,但是它的目的是專門用來提供數據卷供其他容器掛載。

首先,創建一個數據卷容器dbdata,并在其中創建一個數據卷掛載到/dbdata:

$ docker run -it -v /dbdata --name dbdata ubuntu

root@3ed94f279b6f:/#

查看/dbdata目錄:

root@3ed94f279b6f:/# ls

bin? boot? dbdata? dev? etc? home? lib? lib64? media? mnt? opt? proc? root? run sbin? srv? sys? tmp? usr? var

然后,可以在其他容器中使用–volumes-from來掛載dbdata容器中的數據卷.

例如創建db1和db2兩個容器,并從dbdata容器掛載數據卷:

$ docker run -it --volumes-from dbdata --name db1 ubuntu

$ docker run -it --volumes-from dbdata --name db2 ubuntu

此時,容器db1和db2都掛載同一個數據卷到相同的/dbdata目錄。三個容器任何一方在該目錄下的寫入,其他容器都可以看到。

例如,在dbdata容器中創建一個test文件,如下所示:

root@3ed94f279b6f:/# cd /dbdata

root@3ed94f279b6f:/dbdata# touch test

root@3ed94f279b6f:/dbdata# ls

test

在db1容器內查看它:

$ docker run -it --volumes-from dbdata --name db1 ubuntu

root@4128d2d804b4:/# ls

bin boot dbdata dev etc home lib lib64 media mnt opt proc root run sbin srv sys tmp usr var

root@4128d2d804b4:/# ls dbdata/

test

可以多次使用–volumes-from參數來從多個容器掛載多個數據卷。還可以從其他已經掛載了容器卷的容器來掛載數據卷。

使用–volumes-from參數所掛載數據卷的容器自身并不需要保持在運行狀態。

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

利用數據卷容器來遷移數據

可以利用數據卷容器對其中的數據卷進行備份、恢復,以實現數據的遷移。

下面介紹這兩個操作。

1.備份

使用下面的命令來備份dbdata數據卷容器內的數據卷:

$ docker run --volumes-from dbdata -v $(pwd):/backup --name worker ubuntu tar cvf /backup/backup.tar /dbdata

首先利用ubuntu鏡像創建了一個容器worker。使用–volumes-from dbdata參數來讓worker容器掛載dbdata容器的數據卷(即dbdata數據卷),使用-v? $(pwd):/backup參數來掛載本地的當前目錄到worker容器的/backup目錄。worker容器啟動后,使用了tar cvf? /backup/backup.tar /dbdata命令來將/dbdata下內容備份為容器內的/backup/backup.tar,即宿主主機當前目錄下的backup.tar。

2.恢復

如果要將數據恢復到一個容器,可以按照下面的步驟操作。

首先創建一個帶有數據卷的容器dbdata2:

$ docker run -v /dbdata --name dbdata2 ubuntu /bin/bash

然后創建另一個新的容器,掛載dbdata2的容器,并使用untar解壓備份文件到所掛載的容器卷中:

$ docker run --volumes-from dbdata2 -v $(pwd):/backup --name worker ubuntu bash

cd /dbdata

tar xvf /backup/backup.tar
贊(16)
聲明:本網站發布的內容(圖片、視頻和文字)以原創、轉載和分享網絡內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。郵箱:3140448839@qq.com。本站原創內容未經允許不得轉載,或轉載時需注明出處:三五互聯知識庫 » Docker數據管理(數據卷&數據卷容器)

登錄

找回密碼

注冊

主站蜘蛛池模板: 性欧美欧美巨大69| 国产在线98福利播放视频| 亚洲精品麻豆一区二区| 91老熟女老人国产老太| 久久久综合香蕉尹人综合网| 98精品全国免费观看视频| 无码一区二区三区久久精品| 欧洲性开放老太大| 久久99精品久久久久久琪琪| 女同在线观看亚洲国产精品| 国产情侣激情在线对白| 国产精品十八禁在线观看| 国产成人欧美综合在线影院| 亚洲成人精品在线伊人网| 国产午夜福利片在线观看| 无码一区中文字幕| 91精品91久久久久久| 最新精品露脸国产在线| 拍摄av现场失控高潮数次| 久久国产精品99久久蜜臀| 松江区| 开心五月激情综合久久爱| 中文字幕国产精品专区| 国产精品一区二区三区四| 亚洲精品人妻中文字幕| 玩弄放荡人妻少妇系列| 山东省| 性一交一乱一伦| 亚洲av无码专区在线亚| 亚洲国产精品嫩草影院久久| 日本高清在线播放一区二区三区| 国产老熟女狂叫对白| 久久热这里这里只有精品| 视频一区二区不中文字幕| 无码中文字幕av免费放| 精品人妻av区乱码| 一区二区三区鲁丝不卡| 国语精品国内自产视频| 成人一区二区不卡国产| 久久精品国产一区二区蜜芽| 人妻少妇看a偷人无码|