Docker數(shù)據(jù)卷管理的示例分析

這篇文章將為大家詳細(xì)講解有關(guān)Docker數(shù)據(jù)卷管理的示例分析,小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

天門ssl適用于網(wǎng)站、小程序/APP、API接口等需要進(jìn)行數(shù)據(jù)傳輸應(yīng)用場景,ssl證書未來市場廣闊!成為成都創(chuàng)新互聯(lián)的ssl證書銷售渠道,可以享受市場價(jià)格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:18980820575(備注:SSL證書合作)期待與您的合作!

Docker中的數(shù)據(jù)可以存儲在類似于虛擬機(jī)磁盤的介質(zhì)中,在Docker中稱為數(shù)據(jù)卷(Data Volume)。數(shù)據(jù)卷可以用來存儲Docker應(yīng)用的數(shù)據(jù),也可以用來在Docker容器間進(jìn)行數(shù)據(jù)共享。

數(shù)據(jù)卷呈現(xiàn)給Docker容器的形式就是一個(gè)目錄,支持多個(gè)容器間共享,修改也不會影響鏡像。使用Docker的數(shù)據(jù)卷,類似在系統(tǒng)中使用 mount 掛載一個(gè)文件系統(tǒng)。

本節(jié)中,我們需要依次完成下面幾項(xiàng)任務(wù):

1.創(chuàng)建數(shù)據(jù)卷
2.管理數(shù)據(jù)卷權(quán)限
3.掛載宿主機(jī)文件
4.使用數(shù)據(jù)卷容器共享數(shù)據(jù)
5.數(shù)據(jù)卷備份

一、創(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也會自動創(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

Docker數(shù)據(jù)卷管理的示例分析

上述命令中-v參數(shù)可以使用多次,并掛在多個(gè)數(shù)據(jù)卷到容器中。后面的參數(shù)信息中冒號前面是宿主機(jī)的本地目錄,冒號后面是容器中的掛載目錄。

使用docker inspect shiyanlou查看shiyanlou容器中的數(shù)據(jù)卷信息:

#docker inspect shiyanlou

Docker數(shù)據(jù)卷管理的示例分析

進(jìn)入容器后我們可以查看和使用容器卷,嘗試向這個(gè)容器卷中寫入數(shù)據(jù),然后在宿主機(jī)中查看是否存在:

Docker數(shù)據(jù)卷管理的示例分析

可以看到容器中掛載的數(shù)據(jù)卷具備可寫權(quán)限,那么如何對數(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ù)很簡單,ro表示readonly,掛載后的數(shù)據(jù)卷就是只讀權(quán)限了,這時(shí)候我們再次嘗試向數(shù)據(jù)卷中寫入:

Docker數(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

Docker數(shù)據(jù)卷管理的示例分析

如果我們想共享一個(gè)數(shù)據(jù)卷給多個(gè)容器怎么辦,比如設(shè)想一個(gè)場景,我們有兩個(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)建但不啟動數(shù)據(jù)卷容器:

docker create -v /shiyanloudata --name shiyanloudb ubuntu /bin/true

Docker數(shù)據(jù)卷管理的示例分析

其他使用該數(shù)據(jù)卷容器的容器創(chuàng)建時(shí)候需要使用--volumes-from參數(shù),指定該容器名稱或ID:

docker run --volumes-from shiyanloudb ...

創(chuàng)建site1和site2兩個(gè)容器掛載數(shù)據(jù)卷容器shiyanloudb:

Docker數(shù)據(jù)卷管理的示例分析

可以連接到這兩個(gè)容器中對數(shù)據(jù)卷進(jìn)行操作,并查看彼此之間是否已經(jīng)有了共享文件:

Docker數(shù)據(jù)卷管理的示例分析

五、備份數(shù)據(jù)卷

繼續(xù)使用實(shí)驗(yàn)四的環(huán)境,我們對數(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.完成備份操作后容器銷毀

請按照上述步驟對數(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

Docker數(shù)據(jù)卷管理的示例分析

關(guān)于“Docker數(shù)據(jù)卷管理的示例分析”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯(cuò),請把它分享出去讓更多的人看到。

本文題目:Docker數(shù)據(jù)卷管理的示例分析
當(dāng)前網(wǎng)址:http://muchs.cn/article20/pipgco.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供App開發(fā)做網(wǎng)站、網(wǎng)頁設(shè)計(jì)公司電子商務(wù)、虛擬主機(jī)、網(wǎng)站策劃

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)頁設(shè)計(jì)公司