Docker 資料卷,資料卷容器詳細介紹

暖夏未眠丶發表於2018-03-02

摘要:
Docker 資料卷,資料卷容器詳細介紹 引子 有些時候,我們的服務執行時必不可少的會產生一些日誌,或是我們需要把容器內的資料進行備份,甚至多個容器之間進行資料共享,這必然涉及容器的資料管理操作。 容器中管理資料主要有兩種方式: 資料卷 資料卷容器 資料卷是一個可供容器使用的特殊目錄,它繞過檔案系...

Docker 資料卷,資料卷容器詳細介紹

引子

有些時候,我們的服務執行時必不可少的會產生一些日誌,或是我們需要把容器內的資料進行備份,甚至多個容器之間進行資料共享,這必然涉及容器的資料管理操作。

容器中管理資料主要有兩種方式:

資料卷
資料卷容器

資料卷是一個可供容器使用的特殊目錄,它繞過檔案系統,可以提供很多有用的特性:
- 資料卷可以在容器之間共享和重用
- 對資料卷的修改會立馬生效
- 對資料卷的更新,不會影響映象
- 卷會一直存在,直到沒有容器使用

#(類似linux下的掛載(mount))

建立資料卷

在用Docker run 命令的時候,使用-v引數標記可以在容器內建立一個資料卷,多次使用-v標記可以建立多個資料卷

docker run -dp --name web -v /webapp ubuntu:14.04
#這裡我們沒有-p後,並沒有制定埠,如果我們不制定容器與宿主機之間對映的埠關係的話,Docker會隨意對映

掛載一個主機目錄作為資料卷
使用-v標記也可以指定掛載一個本地的已有目錄到容器中去作為資料卷

docker run -dp --name web -v /src/webapp:/opt/webapp ubuntu:1404

上面這條命令載入主機/src/webapp目錄到容器的/opt/webapp目錄:

這個功能在進行測試的時候十分方便,比如使用者可以放置一些程式或資料到本地目錄中,然後在容器內執行和使用。另外,本

地目錄的路徑必須是絕對路徑,如果目錄不存在,Docker會自動建立。

Docker掛載資料卷的預設許可權是讀寫,使用者也可以通過,ro指定只讀:

docker run -dp --name web -v /src/webapp:/opt/webapp:ro ubuntu:14.04
# 加了:ro之後,容器內掛載的資料卷的資料就無法修改。

掛載本機檔案為資料卷

-v標記也可以從主機掛載單個檔案到容器中作為資料卷:

Docker run --rm -it -v ~/.bash_history:/.bash_history ubuntu:14.04
# 這樣就可以記錄在容器輸入過的命令歷史(不同shell版本有所不同)

資料卷容器

如果使用者需要在容器之間共享一些持續更新的資料,最簡單的方式是使用資料卷容器,資料卷容器其實是一個普通的容器,專門用來提供資料卷供其它容器掛載。
首先,建立一個資料卷容器dbdata,並在其中建立一個資料卷掛載到/dbdata:

docker run -ti -v /dbdata --name dbdata ubuntu:14.04

接著我們可以在其他容器中使用–volumes-form來掛載dbdata容器中的資料卷,例如建立db1和db2兩個容器,並從dbdata容器掛載資料卷:

docker run -ti --volumes-from dbdata --name db1 ubuntu:14.04
docker run -ti --volumes-from dbdata --name db2 ubuntu:14.04

此時容器db1和db2都掛載同一個資料捲到相同的/dbdata目錄。三個容器任何一方在該目錄下的寫入,其他容器都可以看到。

例如,在dbdata容器中建立一個test檔案:

root@df392e32f0p6:/# touch test1
root@df392e32f0p6:/#ls
test

我們在db1容器中檢視它:

docker run -ti --volumes-from dbdata --name db1 ubuntu:14.04
root@92597e32f0p6:/# ls dbdata/
test

我們可以多次使用–volumes-from引數來從多個容器掛載多個資料卷。還可以從其他已經掛載了容器卷的容器來掛載資料卷:

docker run -d --name db3 --volumes-from db1 ubuntu:14.04
#注意:使用--volumes-from引數所掛載資料卷的容器自身並不需要保持在執行狀態

如果刪除了掛載的容器(包括dbdata,db1 和 db2),資料卷並不會被自動刪除。如果要刪除一個資料卷,必須在刪除最後一個還掛載著它的容器時顯式使用Docker rm -v命令來指定同時刪除關聯的容器。

使用資料卷容器可以讓使用者在容器之間自由的升級和移動資料卷。

利用資料卷容器遷移資料

可以利用資料卷容器對其中的資料捲進行備份,回覆,以實現資料的遷移。

備份

docker run --volumes-from dbdata -v $(pwd):/backup --name worker ubuntu:14.04 tar cvf /backup/backup.tar /dbdata

這個命令有點複雜,我們來看下這條命令都做了哪寫操作

1.首先利用ubuntu映象建立了一個容器worker。
2.使用–volumes-from dbdata引數來讓worker容器掛載dbdata容器的資料卷(即dbdata資料卷);
3.使用-v $(pwd):/backup引數來掛載本地的當前目錄到worker容器的/backup目錄

worker容器啟動後,使用了tar cvf /backup/backup.tar /dbdata命令來將/dbdata下內容備份為容器內的/backup/backup.tar,即宿主主機當前目錄下的backup.tar。

恢復

如果要恢復資料到一個容器,可以按照下面的操作,首先建立一個帶有資料卷的容器dbdata2:

docker run -v /dbdata --name dbdata2 ubuntu:14.04

然後建立另一個新的容器,掛載dbdata2的容器,並使用ubtar解壓備份檔案到所掛載的容器卷中即可:

docker run --volumes-from dbdata2 -v $(pwd):/backup busybox tar xvf /backup/backup.tar



本文轉自 Mr_sheng 51CTO部落格,原文連結:http://blog.51cto.com/sf1314/1977831


版權宣告:本文內容由網際網路使用者自發貢獻,版權歸作者所有,本社群不擁有所有權,也不承擔相關法律責任。如果您發現本社群中有涉嫌抄襲的內容,歡迎傳送郵件至:yqgroup@service.aliyun.com 進行舉報,並提供相關證據,一經查實,本社群將立刻刪除涉嫌侵權內容。
Docker 資料卷,資料卷容器詳細介紹

用雲棲社群APP,舒服~

原文連結


相關文章