服務(wù)器
生產(chǎn)環(huán)境中使用docker的過(guò)程中,往往需要對數據進(jìn)行持久化,或者需要在多個(gè)容器之間進(jìn)行數據共享,這必然涉及容器的數據管理操作。
容器中管理數據主要有兩種方式:
1.數據卷(Data Volumes):容器內數據直接映射到本地主機環(huán)境;如何在容器內創(chuàng )建數據卷,并且把本地的目錄或文件掛載到容器內的數據卷中。
2.數據卷容器(Data Volume Containers):使用特定容器維護數據卷。如何使用數據卷容器在容器和主機、容器和容器之間共享數據,并實(shí)現數據的備份和恢復。
數據卷
數據卷是一個(gè)可供容器使用的特殊目錄,它將主機操作系統目錄直接映射進(jìn)容器,類(lèi)似于Linux中的mount操作。
數據卷可以提供很多有用的特性,如下所示:
1.數據卷可以在容器之間共享和重用,容器間傳遞數據將變得高效方便;
2.對數據卷內數據的修改會(huì )立馬生效,無(wú)論是容器內操作還是本地操作;
3.對數據卷的更新不會(huì )影響鏡像,解耦了應用和數據;
4.卷會(huì )一直存在,直到?jīng)]有容器使用,可以安全地卸載它。
1.在容器內創(chuàng )建一個(gè)數據卷
在用docker run命令的時(shí)候,使用-v標記可以在容器內創(chuàng )建一個(gè)數據卷。多次重復使用-v標記可以創(chuàng )建多個(gè)數據卷。
下面使用training/webapp鏡像創(chuàng )建一個(gè)web容器,并創(chuàng )建一個(gè)數據卷掛載到容器的/webapp目錄:
$ docker run -d -P --name web -v /webapp training/webapp python app.py
-P是將容器服務(wù)暴露的端口,是自動(dòng)映射到本地主機的臨時(shí)端口。
2.掛載一個(gè)主機目錄作為數據卷
使用-v標記也可以指定掛載一個(gè)本地的已有目錄到容器中去作為數據卷(推薦方式)。
$ docker run -d -P --name web -v /src/webapp:/opt/webapp training/webapp python app.py
上面的命令加載主機的/src/webapp目錄到容器的/opt/webapp目錄。
這個(gè)功能在進(jìn)行測試的時(shí)候十分方便,比如用戶(hù)可以將一些程序或數據放到本地目錄中,然后在容器內運行和使用。另外,本地目錄的路徑必須是絕對路徑,如果目錄不存在,Docker會(huì )自動(dòng)創(chuàng )建。
Docker掛載數據卷的默認權限是讀寫(xiě)(rw),用戶(hù)也可以通過(guò)ro指定為只讀:
$ docker run -d -P --name web -v /src/webapp:/opt/webapp:ro training/webapp python app.py
加了:ro之后,容器內對所掛載數據卷內的數據就無(wú)法修改了。
3.掛載一個(gè)本地主機文件作為數據卷
-v標記也可以從主機掛載單個(gè)文件到容器中作為數據卷(不推薦)。
$ docker run --rm -it -v ~/.bash_history:/.bash_history ubuntu /bin/bash
這樣就可以記錄在容器輸入過(guò)的命令歷史了。
如果直接掛載一個(gè)文件到容器,使用文件編輯工具,包括vi或者sed–in-place的時(shí)候,可能會(huì )造成文件inode的改變,從Docker 1.1.0起,這會(huì )導致報錯誤信息。所以推薦的方式是直接掛載文件所在的目錄。
數據卷容器
如果用戶(hù)需要在多個(gè)容器之間共享一些持續更新的數據,最簡(jiǎn)單的方式是使用數據卷容器。數據卷容器也是一個(gè)容器,但是它的目的是專(zhuān)門(mén)用來(lái)提供數據卷供其他容器掛載。
首先,創(chuàng )建一個(gè)數據卷容器dbdata,并在其中創(chuàng )建一個(gè)數據卷掛載到/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來(lái)掛載dbdata容器中的數據卷.
例如創(chuàng )建db1和db2兩個(gè)容器,并從dbdata容器掛載數據卷:
$ docker run -it --volumes-from dbdata --name db1 ubuntu $ docker run -it --volumes-from dbdata --name db2 ubuntu
此時(shí),容器db1和db2都掛載同一個(gè)數據卷到相同的/dbdata目錄。三個(gè)容器任何一方在該目錄下的寫(xiě)入,其他容器都可以看到。
例如,在dbdata容器中創(chuàng )建一個(gè)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參數來(lái)從多個(gè)容器掛載多個(gè)數據卷。還可以從其他已經(jīng)掛載了容器卷的容器來(lái)掛載數據卷。
使用–volumes-from參數所掛載數據卷的容器自身并不需要保持在運行狀態(tài)。
如果刪除了掛載的容器(包括dbdata、db1和db2),數據卷并不會(huì )被自動(dòng)刪除。如果要刪除一個(gè)數據卷,必須在刪除最后一個(gè)還掛載著(zhù)它的容器時(shí)顯式使用docker rm -v命令來(lái)指定同時(shí)刪除關(guān)聯(lián)的容器。
利用數據卷容器來(lái)遷移數據
可以利用數據卷容器對其中的數據卷進(jìn)行備份、恢復,以實(shí)現數據的遷移。
下面介紹這兩個(gè)操作。
1.備份
使用下面的命令來(lái)備份dbdata數據卷容器內的數據卷:
復制代碼 代碼如下:$ docker run –volumes-from dbdata -v $(pwd):/backup –name worker ubuntu tar cvf /backup/backup.tar /dbdata
首先利用ubuntu鏡像創(chuàng )建了一個(gè)容器worker。使用–volumes-from dbdata參數來(lái)讓worker容器掛載dbdata容器的數據卷(即dbdata數據卷),使用-v $(pwd):/backup參數來(lái)掛載本地的當前目錄到worker容器的/backup目錄。worker容器啟動(dòng)后,使用了tar cvf /backup/backup.tar /dbdata命令來(lái)將/dbdata下內容備份為容器內的/backup/backup.tar,即宿主主機當前目錄下的backup.tar。
2.恢復
如果要將數據恢復到一個(gè)容器,可以按照下面的步驟操作。
首先創(chuàng )建一個(gè)帶有數據卷的容器dbdata2:
$ docker run -v /dbdata –name dbdata2 ubuntu /bin/bash
然后創(chuàng )建另一個(gè)新的容器,掛載dbdata2的容器,并使用untar解壓備份文件到所掛載的容器卷中:
$ docker run --volumes-from dbdata2 -v $(pwd):/backup --name worker ubuntu bash cd /dbdata tar xvf /backup/backup.tar
以上就是本文的全部?jì)热?,希望對大家的學(xué)習有所幫助,也希望大家多多支持特網(wǎng)科技。
更多關(guān)于云服務(wù)器,域名注冊,虛擬主機的問(wèn)題,請訪(fǎng)問(wèn)特網(wǎng)科技官網(wǎng):wap.friendlycc.com.cn
免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng )、來(lái)自本網(wǎng)站內容采集于網(wǎng)絡(luò )互聯(lián)網(wǎng)轉載等其它媒體和分享為主,內容觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如侵犯了原作者的版權,請告知一經(jīng)查實(shí),將立刻刪除涉嫌侵權內容,聯(lián)系我們QQ:712375056,同時(shí)歡迎投稿傳遞力量。
Copyright ? 2009-2022 56dr.com. All Rights Reserved. 特網(wǎng)科技 特網(wǎng)云 版權所有 特網(wǎng)科技 粵ICP備16109289號
域名注冊服務(wù)機構:阿里云計算有限公司(萬(wàn)網(wǎng)) 域名服務(wù)機構:煙臺帝思普網(wǎng)絡(luò )科技有限公司(DNSPod) CDN服務(wù):阿里云計算有限公司 百度云 中國互聯(lián)網(wǎng)舉報中心 增值電信業(yè)務(wù)經(jīng)營(yíng)許可證B2
建議您使用Chrome、Firefox、Edge、IE10及以上版本和360等主流瀏覽器瀏覽本網(wǎng)站