詳解Docker 數(shù)據(jù)卷管理
Docker中的數(shù)據(jù)可以存儲(chǔ)在類似于虛擬機(jī)磁盤的介質(zhì)中,在Docker中稱為數(shù)據(jù)卷(Data Volume
)。數(shù)據(jù)卷可以用來(lái)存儲(chǔ)Docker應(yīng)用的數(shù)據(jù),也可以用來(lái)在Docker容器間進(jìn)行數(shù)據(jù)共享。
數(shù)據(jù)卷呈現(xiàn)給Docker容器的形式就是一個(gè)目錄,支持多個(gè)容器間共享,修改也不會(huì)影響鏡像。使用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
用來(lái)創(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源就能夠影響到所有的容器。
如果我們想共享一個(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
總結(jié)
1.創(chuàng)建數(shù)據(jù)卷
2.管理數(shù)據(jù)卷權(quán)限
3.掛載宿主機(jī)文件
4.使用數(shù)據(jù)卷容器共享數(shù)據(jù)
5.數(shù)據(jù)卷備份
請(qǐng)務(wù)必保證自己能夠動(dòng)手完成整個(gè)實(shí)驗(yàn),只看文字很簡(jiǎn)單,真正操作的時(shí)候會(huì)遇到各種各樣的問題,解決問題的過(guò)程才是收獲的過(guò)程。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
利用 Docker 構(gòu)建簡(jiǎn)單的 java 開發(fā)編譯環(huán)境的方法詳解
這篇文章主要介紹了利用 Docker 構(gòu)建簡(jiǎn)單的 java 開發(fā)編譯環(huán)境的相關(guān)知識(shí),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-11-11docker容器動(dòng)態(tài)添加端口號(hào)的方法
這篇文章主要介紹了docker容器動(dòng)態(tài)添加端口號(hào)的方法,本文分步驟給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-05-05Docker執(zhí)行DockerFile構(gòu)建過(guò)程指令解析
這篇文章主要為大家介紹了Docker執(zhí)行DockerFile構(gòu)建過(guò)程及DockerFile的指令解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪<BR>2022-04-04.NETCore Docker實(shí)現(xiàn)容器化與私有鏡像倉(cāng)庫(kù)管理
Docker是用Go語(yǔ)言編寫基于Linux操作系統(tǒng)的一些特性開發(fā)的,其提供了操作系統(tǒng)級(jí)別的抽象,是一種容器管理技術(shù),它隔離了應(yīng)用程序?qū)A(chǔ)架構(gòu)(操作系統(tǒng)等)的依賴。這篇文章主要介紹了.NETCore Docker實(shí)現(xiàn)容器化與私有鏡像倉(cāng)庫(kù)管理,需要的朋友可以參考下2019-08-08使用Docker快速搭建Airflow+MySQL詳細(xì)步驟
本文詳細(xì)介紹了如何使用Docker和Docker Compose安裝并配置Apache Airflow 2.9.3,步驟包括創(chuàng)建項(xiàng)目目錄、編寫docker-compose.yml文件、創(chuàng)建所需目錄結(jié)構(gòu)、啟動(dòng)和管理Docker容器,以及如何訪問和配置Airflow Web UI,感興趣的朋友跟隨小編一起看看吧2024-09-09SpringBoot 整合 Docker的詳細(xì)過(guò)程
這篇文章主要介紹了SpringBoot 整合 Docker的詳細(xì)過(guò)程,本文通過(guò)一個(gè)簡(jiǎn)單的項(xiàng)目來(lái)給大家介紹整合的詳細(xì)過(guò)程,需要的朋友可以參考下2021-11-11