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版本有所不同)
數據卷容器
如果用戶需要在容器之間共享一些持續更新的數據,最簡單的方式是使用數據卷容器,數據卷容器其實是一個普通的容器,專門用來提供數據卷供其它容器掛載。
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 數據卷,數據卷容器詳細介紹