十年網(wǎng)站開發(fā)經(jīng)驗(yàn) + 多家企業(yè)客戶 + 靠譜的建站團(tuán)隊(duì)
量身定制 + 運(yùn)營(yíng)維護(hù)+專業(yè)推廣+無憂售后,網(wǎng)站問題一站解決
這篇文章主要介紹了Docker數(shù)據(jù)卷如何管理的相關(guān)知識(shí),內(nèi)容詳細(xì)易懂,操作簡(jiǎn)單快捷,具有一定借鑒價(jià)值,相信大家閱讀完這篇Docker數(shù)據(jù)卷如何管理文章都會(huì)有所收獲,下面我們一起來看看吧。
創(chuàng)新互聯(lián)2013年開創(chuàng)至今,是專業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項(xiàng)目網(wǎng)站設(shè)計(jì)、做網(wǎng)站網(wǎng)站策劃,項(xiàng)目實(shí)施與項(xiàng)目整合能力。我們以讓每一個(gè)夢(mèng)想脫穎而出為使命,1280元安陽(yáng)做網(wǎng)站,已為上家服務(wù),為安陽(yáng)各地企業(yè)和個(gè)人服務(wù),聯(lián)系電話:18980820575
一、創(chuàng)建數(shù)據(jù)卷
容器管理實(shí)驗(yàn)中我們學(xué)習(xí)的命令docker run
用來創(chuàng)建容器,可以在使用改命令時(shí)添加-v
參數(shù),就可以創(chuàng)建并掛載一個(gè)到多個(gè)數(shù)據(jù)卷到當(dāng)前運(yùn)行的容器中,-v
的作用是將宿主機(jī)的一個(gè)目錄作為容器的數(shù)據(jù)卷掛載到容器中,使宿主機(jī)和容器之間可以共享一個(gè)目錄,如果本地路徑不存在,docker也會(huì)自動(dòng)創(chuàng)建。
本節(jié)實(shí)驗(yàn)中,我們掛載2個(gè)數(shù)據(jù)卷到新創(chuàng)建的容器上:
# 創(chuàng)建兩個(gè)目錄 mkdir /tmp/data1 /tmp/data2 # 分別將兩個(gè)目錄掛載到新創(chuàng)建的容器上 docker run -t -i --name shiyanlou -v /tmp/data1:/data1 -v /tmp/data2:/data2 ubuntu /bin/bash
上述命令中-v
參數(shù)可以使用多次,并掛在多個(gè)數(shù)據(jù)卷到容器中。后面的參數(shù)信息中冒號(hào)前面是宿主機(jī)的本地目錄,冒號(hào)后面是容器中的掛載目錄。
使用docker inspect shiyanlou
查看shiyanlou容器中的數(shù)據(jù)卷信息:
#docker inspect shiyanlou
進(jìn)入容器后我們可以查看和使用容器卷,嘗試向這個(gè)容器卷中寫入數(shù)據(jù),然后在宿主機(jī)中查看是否存在:
可以看到容器中掛載的數(shù)據(jù)卷具備可寫權(quán)限,那么如何對(duì)數(shù)據(jù)卷的權(quán)限進(jìn)行管理呢?比如如何創(chuàng)建一個(gè)只讀的數(shù)據(jù)卷呢?
二、數(shù)據(jù)卷權(quán)限
掛載的數(shù)據(jù)卷默認(rèn)為可讀寫權(quán)限,除非外部文件系統(tǒng)做了特殊限制,在docker run
的時(shí)候也可以執(zhí)行為只讀
權(quán)限:
# 創(chuàng)建一個(gè)數(shù)據(jù)卷目錄 mkdir /tmp/readonlydata # 以只讀的方式掛載到shiyanlouro容器上 docker run -t -i --name shiyanlouro -v /tmp/readonlydata:/rodata:ro ubuntu /bin/bash
上面的命令中參數(shù)很簡(jiǎn)單,ro
表示readonly
,掛載后的數(shù)據(jù)卷就是只讀權(quán)限了,這時(shí)候我們?cè)俅螄L試向數(shù)據(jù)卷中寫入:
除了可以掛載目錄之外,文件也可以作為數(shù)據(jù)卷掛載到容器中。
三、掛載宿主機(jī)上的文件
在本實(shí)驗(yàn)中,我們想讓所有的容器都可以共享宿主機(jī)的/etc/apt/sources.list
,從而只需要改變宿主機(jī)的apt源就能夠影響到所有的容器。
復(fù)制代碼 代碼如下:
docker run -t -i --name shiyanloufile -v /etc/apt/sources.list:/etc/apt/sources.list:ro ubuntu /bin/bash
如果我們想共享一個(gè)數(shù)據(jù)卷給多個(gè)容器怎么辦,比如設(shè)想一個(gè)場(chǎng)景,我們有兩個(gè)處理上傳數(shù)據(jù)的應(yīng)用運(yùn)行在不同的容器中,但需要同時(shí)讀取同一個(gè)文件夾下的文件,此時(shí),最好的方式是使用數(shù)據(jù)卷容器。
四、數(shù)據(jù)卷容器
如果需要在多個(gè)容器間共享數(shù)據(jù),并希望永久保存這些數(shù)據(jù),最好的方式是使用數(shù)據(jù)卷容器,類似于一個(gè)提供網(wǎng)絡(luò)文件共享服務(wù)的nfs服務(wù)器。
數(shù)據(jù)卷容器創(chuàng)建方法跟普通容器一樣,只需要指定宿主機(jī)的一個(gè)文件夾作為數(shù)據(jù)卷即可,使用docker create
命令創(chuàng)建但不啟動(dòng)數(shù)據(jù)卷容器:
docker create -v /shiyanloudata --name shiyanloudb ubuntu /bin/true
其他使用該數(shù)據(jù)卷容器的容器創(chuàng)建時(shí)候需要使用--volumes-from
參數(shù),指定該容器名稱或id:
docker run --volumes-from shiyanloudb ...
創(chuàng)建site1和site2兩個(gè)容器掛載數(shù)據(jù)卷容器shiyanloudb:
可以連接到這兩個(gè)容器中對(duì)數(shù)據(jù)卷進(jìn)行操作,并查看彼此之間是否已經(jīng)有了共享文件:
五、備份數(shù)據(jù)卷
繼續(xù)使用實(shí)驗(yàn)四的環(huán)境,我們對(duì)數(shù)據(jù)卷容器中的數(shù)據(jù)進(jìn)行備份,備份方法:
1.創(chuàng)建一個(gè)新的容器
2.掛載數(shù)據(jù)卷容器
3.掛載宿主機(jī)本地目錄作為數(shù)據(jù)卷
4.將數(shù)據(jù)卷容器的內(nèi)容備份到宿主機(jī)本地目錄掛載的數(shù)據(jù)卷中
5.完成備份操作后容器銷毀
請(qǐng)按照上述步驟對(duì)數(shù)據(jù)卷容器shiyanloudb中的數(shù)據(jù)進(jìn)行備份:
# 創(chuàng)建備份目錄 mkdir /tmp/backup # 創(chuàng)建備份容器 docker run --rm --volumes-from shiyanloudb -v /tmp/backup:/backup ubuntu tar cvf /backup/shiyanloudb.tar /shiyanloudata
關(guān)于“Docker數(shù)據(jù)卷如何管理”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對(duì)“Docker數(shù)據(jù)卷如何管理”知識(shí)都有一定的了解,大家如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。