1. 程式人生 > >Docker 數據卷,數據卷容器詳細介紹

Docker 數據卷,數據卷容器詳細介紹

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



本文出自 “愛生活的小白” 博客,請務必保留此出處http://sf1314.blog.51cto.com/13295031/1977831

Docker 數據卷,數據卷容器詳細介紹