之前寫過一篇關(guān)于Docker容器和本機(jī)之間的文件傳輸。的文章,但是此方法相對(duì)比較繁瑣一些,在查看了官方關(guān)于數(shù)據(jù)管理的文檔之后發(fā)現(xiàn)利用volume來實(shí)現(xiàn)主機(jī)和容器的文件傳輸效率更高一點(diǎn),其實(shí)也就是將本地的目錄進(jìn)行掛載到容器上,官方一共有三種方法:Manage data in Docker,
這里只介紹使用volume的操作:Use volumes
1.使用Volume在主機(jī)和容器之間傳輸文件。
在官方文檔中可以看到使用如下命令即可創(chuàng)建一個(gè)volume:
Create a volume:
$ docker volume create my-vol
注意這個(gè)命令不是所有的docker版本都可以運(yùn)行的:
The client and daemon API must both be at least 1.21 to use this command. Use the docker version command on the client to check your client and daemon API versions.
創(chuàng)建完成之后可以查看詳細(xì)信息:
$ docker volume inspect my-vol
注意這個(gè)Mountpoint所對(duì)應(yīng)的目錄就是我們用來主機(jī)和容器進(jìn)行文件傳輸?shù)哪夸洝?/p>
然后在使用run啟動(dòng)一個(gè)容器的時(shí)候就可以使用該volume:
可以看到通過-v命令將剛才創(chuàng)建的數(shù)據(jù)卷掛載到容器中的hostdata目錄下了,這時(shí)候我們在容器中給hostdata目錄下添加文件的時(shí)候,在主機(jī)的的/var/lib/docker/volumes/my-vol/_data中就可以看到了,同理在主機(jī)的該目錄中添加文件,在容器的hostdata中也可以看到。
我將nginx這個(gè)文件復(fù)制到主機(jī)中用來交換的目錄下,進(jìn)入容器之后在hostdata的目錄下也可以查看:
同樣的在容器中將文件拷貝到hostdata目錄下中,在主機(jī)的/var/lib/docker/volumes/my-vol/_data也能夠使用查看。
在這里我在容器中創(chuàng)建一個(gè)文件testfile并向其中寫入:This is container write!,然后回到主機(jī)進(jìn)行查看,并在主機(jī)中使用vim向其中添加:“This is host write!”,并返回容器中進(jìn)行查看。
2.使用數(shù)據(jù)卷容器。
我在有些地方看到有人使用數(shù)據(jù)卷容器來實(shí)現(xiàn)多個(gè)容器之間的數(shù)據(jù)共享,其過程是這樣子的:
1.先創(chuàng)建一個(gè)數(shù)據(jù)卷容器dbdata,并在其中創(chuàng)建一個(gè)數(shù)據(jù)卷掛載到/bdata:
可以通過docker volume ls查看生成了一個(gè)隨機(jī)名稱的volume。
2.然后,可以在其他容器中使用–volumes-from來掛載dbdata容器中的數(shù)據(jù)卷,例如創(chuàng)建db1和db2兩個(gè)容器,并從dbdata容器掛載數(shù)據(jù)卷:
3.然后此時(shí)在三個(gè)容器中任何一方在/dbdata目錄下的寫入,其他容器中都可以看到。
在圖中,在dbdata容器中創(chuàng)建testfile文件并寫入”dbdata container write!”,然后在db1容器中查看并寫入“db1 container write!”,然后在db2容器中查看并寫入“da2 container write!”,最后回到dbdata容器中查看。
4.然后還可以通過多個(gè)–volumes-from來掛載多個(gè)數(shù)據(jù)卷,然后還給出了備份和恢復(fù)的方法,網(wǎng)上一搜一大把。
3.為什么不用數(shù)據(jù)卷容器?
在看到許許多多關(guān)于數(shù)據(jù)卷容器的文章,并且都是大同小異。然后我想了想發(fā)現(xiàn)并沒有使用數(shù)據(jù)卷的必要性(或許是我想的不夠周全)。
上面提到數(shù)據(jù)卷容器用來在多個(gè)容器中共享數(shù)據(jù),但是在明明可以通過掛載一個(gè)相同的本地目錄就能實(shí)現(xiàn)該方法。比如說在第一步中創(chuàng)建的my-vol數(shù)據(jù)卷,我可以將其同時(shí)掛載到db3和db4容器中。
在圖中,我將my-vol數(shù)據(jù)卷掛載到了db3和db4中,然后在其中能夠找到之前的數(shù)據(jù)文件,并且在db4容器中對(duì)testfile文件進(jìn)行寫入操作,在db3中容器中也可以查看。
那么也就是說,我同樣的可以通過掛載一個(gè)數(shù)據(jù)卷就可以實(shí)現(xiàn)多個(gè)容器中的數(shù)據(jù)共享,并且在主機(jī)的目錄中添加的文件,在所有的容器中也能夠查看。如果備份的話直接在主機(jī)本地將文件夾進(jìn)行拷貝即可,豈不是更方便。
4.為什么使用數(shù)據(jù)卷容器?
但是數(shù)據(jù)卷容器還有一個(gè)作用比較不錯(cuò),那就是可以用來指定掛載本地目錄,在第一點(diǎn)中我們創(chuàng)建一個(gè)名為my-vol的數(shù)據(jù)卷,該數(shù)據(jù)卷在本地存放的目錄為:/var/lib/docker/volumes/my-vol/_data,可以看出這個(gè)名字很長不方便操作,可以通過數(shù)據(jù)卷容器來解決該問題。
比如我在主機(jī)上創(chuàng)建了一個(gè)專門用來存放主機(jī)和容器進(jìn)行文件交互的目錄,也就是說以后我想給容器中傳輸什么文件了,我直接將文件拷貝到該目錄下即可:
我在官方文檔中并沒有發(fā)現(xiàn)使用docker volume create 創(chuàng)建數(shù)據(jù)卷時(shí)可以指定volume對(duì)應(yīng)的本地目錄的命令(或許是我看的不夠多)。
但是我就是想要用/usr/local/datadb 這個(gè)目錄該怎么辦?此刻數(shù)據(jù)卷容器的作用就出來了,可以通過創(chuàng)建一個(gè)數(shù)據(jù)卷容器,并且將該目錄掛在到數(shù)據(jù)卷容器上即可:
在圖中,我創(chuàng)建了一個(gè)所謂的數(shù)據(jù)卷容器,并且使用-v參數(shù),將剛才主機(jī)的/usr/local/datadb目錄掛載進(jìn)去,然后在容器中創(chuàng)建文件testfile并寫入“HAHAHAHA”,在主機(jī)上進(jìn)行查看。
然后在其他容器創(chuàng)建的時(shí)候既可以使用–volumes-from將該數(shù)據(jù)卷容器進(jìn)行掛載,然后想給容器中傳文件的時(shí)候直接拷貝到/usr/local/datadb目錄下即可,反過來容器給主機(jī)傳文件直接拷貝到容器中的掛載目錄下即可。
至于備份,直接將主機(jī)/usr/local/datadb賦值一份就好了,恢復(fù)的話再次掛載就好了。
但有一個(gè)問題就是,上述所有的掛載volume操作都是使用run命令新建了一個(gè)容器,至于能不能直接給運(yùn)行中的容器進(jìn)行掛載,我查了半天只有一個(gè)是關(guān)于這個(gè)的,但是我也沒有考證,有興趣的可以看下:https://www.jb51.net/article/157179.htm
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。