Docker 教程之?dāng)?shù)據(jù)管理詳細(xì)介紹
Docker 數(shù)據(jù)管理
用戶在使用 Docker 的過(guò)程中,往往需要能查看容器內(nèi)應(yīng)用產(chǎn)生的數(shù)據(jù),或者需要把容器內(nèi)的數(shù)據(jù)進(jìn)行備份,甚至多個(gè)容器之間進(jìn)行數(shù)據(jù)的共享,這必然涉及容器的數(shù)據(jù)管理操作。容器中管理數(shù)據(jù)主要有兩種方式:數(shù)據(jù)卷(Data Volumes),數(shù)據(jù)卷容器(Data Volume Containers)。
數(shù)據(jù)卷
數(shù)據(jù)卷是一個(gè)可供容器使用的特殊目錄,它繞過(guò)文件系統(tǒng),可以提供很多有用的特性:
1. 數(shù)據(jù)卷可以在容器之間共享和重用。
2. 對(duì)數(shù)據(jù)卷的更改會(huì)立即生效。
3. 對(duì)數(shù)據(jù)卷的更新不會(huì)影響鏡像。
4. 數(shù)據(jù)卷會(huì)一直存在,直到?jīng)]有容器使用。
數(shù)據(jù)卷的使用,類(lèi)似于 linux 下對(duì)目錄或文件進(jìn)行 mount 操作。
在容器內(nèi)創(chuàng)建一個(gè)數(shù)據(jù)卷
在用 docker run 命令的時(shí)候,使用 -v 標(biāo)記可以在容器內(nèi)創(chuàng)建一個(gè)數(shù)據(jù)卷。多次使用 -v 標(biāo)記可以創(chuàng)建多個(gè)數(shù)據(jù)卷。
下面的例子中我們使用 myimg/webapp 鏡像創(chuàng)建一個(gè) web 容器,并創(chuàng)建一個(gè)數(shù)據(jù)卷掛載到容器的 /webdata 目錄。
$ sudo docker run -d -P –name web -v /webdata myimg/webapp python app.py
掛載一個(gè)主機(jī)目錄作為數(shù)據(jù)卷
使用 -v 標(biāo)記也可以指定掛載一個(gè)本地的已有目錄到容器中去作為數(shù)據(jù)卷:
$ sudo docker run -d -P –name web -v /var/data:/opt/webdata myimg/webapp python app.py
上面的命令掛載主機(jī)的 /var/data 目錄到容器的 /opt/webdata 目錄。
這個(gè)功能在接下測(cè)試的時(shí)候特別方便,比如用戶可以放置一些程序或數(shù)據(jù)到本地目錄中,然后在容器中使用。另外,本地目錄的路徑必須是絕對(duì)路徑,如果目錄不存在,Docker 會(huì)自動(dòng)創(chuàng)建。
Docker 掛載數(shù)據(jù)卷的默認(rèn)權(quán)限是可讀寫(xiě)(rw),用戶也可以通過(guò) ro 標(biāo)記指定為只讀:
$ sudo docker run -d -P –name web -v /var/data:/opt/webdata:ro myimg/webapp python app.py
加了 :ro 之后,容器內(nèi)掛載的數(shù)據(jù)卷內(nèi)的數(shù)據(jù)就變成只讀的了。
掛載一個(gè)本地主機(jī)文件作為數(shù)據(jù)卷
-v 標(biāo)記也可以掛載一個(gè)主機(jī)中的文件到容器中作為數(shù)據(jù)卷,但是這樣做會(huì)帶來(lái)一些問(wèn)題。建議還是掛載文件所在的目錄。
數(shù)據(jù)卷容器
如果用戶需要在容器之間共享一些持續(xù)更新的數(shù)據(jù),最簡(jiǎn)單的方式是使用數(shù)據(jù)卷容器。數(shù)據(jù)卷容器其實(shí)就是一個(gè)普通的容器,專(zhuān)門(mén)用它提供數(shù)據(jù)卷供其他容器掛載。下面簡(jiǎn)單介紹其使用方法。
首先要?jiǎng)?chuàng)建一個(gè)數(shù)據(jù)卷容器 mydata,并在其中創(chuàng)建一個(gè)數(shù)據(jù)卷掛載到 /data 目錄。
$ sudo docker run -it -v /data –name mydata ubuntu
然后在其他容器中使用 --volumes-from 來(lái)掛載 mydata 容器中的數(shù)據(jù)卷。例如創(chuàng)建兩個(gè)容器 mycon1 和 mycon2,并從 mydata 容器掛載數(shù)據(jù)卷:
$ sudo docker run -it --volumes-from mydata –name mycon1 ubuntu $ sudo docker run -it --volumes-from mydata –name mycon2 ubuntu
(注意,命令中沒(méi)有指定數(shù)據(jù)卷的信息,也就是說(shuō)新容器中掛載數(shù)據(jù)卷的目錄和源容器中是一樣的。)
此時(shí)容器 mycon1 和 mycon2 都掛載同一個(gè)數(shù)據(jù)卷到相同的目錄 /data。三個(gè)容器任何一個(gè)在該目錄下寫(xiě)入數(shù)據(jù)其他容器都能看到。
可以多次使用 --volumes-from 參數(shù)來(lái)從多個(gè)容器掛載多個(gè)數(shù)據(jù)卷。還可以從其他已經(jīng)掛載了容器的容器來(lái)掛載數(shù)據(jù)卷。并且使用 --volumes-from 參數(shù)所掛載數(shù)據(jù)卷的容器自身并不需要保持在運(yùn)行狀態(tài)。
但刪除掛載了數(shù)據(jù)卷的容器時(shí),數(shù)據(jù)卷并不會(huì)被自動(dòng)刪除。如果要?jiǎng)h除一個(gè)數(shù)據(jù)卷,必須在刪除最后一個(gè)還掛載著它的容器時(shí)顯式的使用 docker rm -v 命令來(lái)指定同時(shí)刪除關(guān)聯(lián)的容器。
使用數(shù)據(jù)卷容器可以讓用戶在容器之間自由的升級(jí)和移動(dòng)數(shù)據(jù)卷,下面會(huì)進(jìn)行詳細(xì)的介紹。
利用數(shù)據(jù)卷容器遷移數(shù)據(jù)
可以利用數(shù)據(jù)卷容器對(duì)其中的數(shù)據(jù)卷進(jìn)行備份、恢復(fù),以實(shí)現(xiàn)數(shù)據(jù)的遷移。
備份
使用下面的命令來(lái)備份 mydata 數(shù)據(jù)卷容器內(nèi)的數(shù)據(jù)卷:
$ sudo docker run --volumes-from mydata -v $(pwd):/backup –name worker ubuntu tar cvf /backup/backup.tar /data
這個(gè)命令首先利用 Ubuntu 鏡像創(chuàng)建了一個(gè)容器 worker。又使用 --volumes-from mydata 參數(shù)來(lái)讓 worker 容器掛載 mydata 容器的數(shù)據(jù)卷。接下來(lái)使用 -v $(pwd):/backup 參數(shù)來(lái)掛載本地的當(dāng)前目錄到 worker 容器的 /backup 目錄。
在 worker 容器啟動(dòng)后,使用了 tar cvf /backup/backup.tar /data 命令來(lái)將 /data 下內(nèi)容備份為容器內(nèi)的 /backup/backup.tar,即宿主主機(jī)的當(dāng)前目錄下的backup.tar。
恢復(fù)
如果要恢復(fù)數(shù)據(jù)到一個(gè)容器,可以按照下面的操作。首先創(chuàng)建一個(gè)帶有數(shù)據(jù)卷的容器 mydata2:
$ sudo docker run -v /data –name mydata2 ubuntu /bin/bash
然后創(chuàng)建另一個(gè)新的容器,掛載 mydata2 的數(shù)據(jù)卷,并使用 tar 解壓縮備份文件到所掛載的容器卷中:
$ sudo docker run --volumes-from mydata2 -v $(pwd):/backup busybox tar xvf /backup/backup.tar
感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
相關(guān)文章
使用docker搭建go環(huán)境的簡(jiǎn)單步驟
最近公司里面的項(xiàng)目用到了Docker,正好準(zhǔn)備學(xué)習(xí)下Golang,所以就學(xué)習(xí)Golang順便也學(xué)習(xí)下Docker怎么用的,剛好從頭開(kāi)始配置下環(huán)境,這篇文章主要給大家介紹了關(guān)于使用docker搭建go環(huán)境的簡(jiǎn)單步驟,需要的朋友可以參考下2023-10-10使用docker?部署mysql突然連接不上的問(wèn)題及解決方法
這篇文章主要介紹了使用docker?部署mysql,突然連接不上,要解決這個(gè)問(wèn)題需要找到根本原因,對(duì)癥治療就好,本文通過(guò)圖文實(shí)例相結(jié)合給大家介紹的非常詳細(xì),需要的朋友可以參考下2022-06-06Docker在Windows環(huán)境的搭建和使用詳解
這篇文章主要介紹了Docker在Windows環(huán)境的搭建和使用,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-03-03Docker容器通過(guò)獨(dú)立IP暴露給局域網(wǎng)的方法
這篇文章主要介紹了Docker容器通過(guò)獨(dú)立IP暴露給局域網(wǎng)的方法,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-04-04docker rm -f 容器id 無(wú)效的問(wèn)題解決
當(dāng)遇到“Error response from daemon: cannot stop container: d208b8055fd0: permission denied”錯(cuò)誤,表示缺乏停止Docker容器的權(quán)限,本文就來(lái)介紹一下如何解決,感興趣的可以了解一下2024-09-09給debian的docker容器添加crontab定時(shí)任務(wù)
這篇文章主要介紹了給debian的docker容器添加crontab定時(shí)任務(wù)的相關(guān)知識(shí),非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-08-08docker搭建tomcat運(yùn)行環(huán)境的實(shí)現(xiàn)步驟
很多時(shí)候我們測(cè)試web系統(tǒng)需要一個(gè)tomcat運(yùn)行環(huán)境,這時(shí)docker就派上用場(chǎng)了,本篇文章主要介紹了docker搭建tomcat運(yùn)行環(huán)境的實(shí)現(xiàn)步驟,感興趣的可以了解一下2017-01-01