您好,登錄后才能下訂單哦!
本文小編為大家詳細(xì)介紹“如何用Volume在主機和Docker間進(jìn)行文件傳輸”,內(nèi)容詳細(xì),步驟清晰,細(xì)節(jié)處理妥當(dāng),希望這篇“如何用Volume在主機和Docker間進(jìn)行文件傳輸”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學(xué)習(xí)新知識吧。
1.使用volume在主機和容器之間傳輸文件。
在官方文檔中可以看到使用如下命令即可創(chuàng)建一個volume:
create a volume:
$ docker volume create my-vol
注意這個命令不是所有的docker版本都可以運行的:
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
注意這個mountpoint所對應(yīng)的目錄就是我們用來主機和容器進(jìn)行文件傳輸?shù)哪夸洝?/p>
然后在使用run啟動一個容器的時候就可以使用該volume:
可以看到通過-v命令將剛才創(chuàng)建的數(shù)據(jù)卷掛載到容器中的hostdata目錄下了,這時候我們在容器中給hostdata目錄下添加文件的時候,在主機的的/var/lib/docker/volumes/my-vol/_data中就可以看到了,同理在主機的該目錄中添加文件,在容器的hostdata中也可以看到。
我將nginx這個文件復(fù)制到主機中用來交換的目錄下,進(jìn)入容器之后在hostdata的目錄下也可以查看:
同樣的在容器中將文件拷貝到hostdata目錄下中,在主機的/var/lib/docker/volumes/my-vol/_data也能夠使用查看。
在這里我在容器中創(chuàng)建一個文件testfile并向其中寫入:this is container write!,然后回到主機進(jìn)行查看,并在主機中使用vim向其中添加:“this is host write!”,并返回容器中進(jìn)行查看。
2.使用數(shù)據(jù)卷容器。
我在有些地方看到有人使用數(shù)據(jù)卷容器來實現(xiàn)多個容器之間的數(shù)據(jù)共享,其過程是這樣子的:
1.先創(chuàng)建一個數(shù)據(jù)卷容器dbdata,并在其中創(chuàng)建一個數(shù)據(jù)卷掛載到/bdata:
可以通過docker volume ls查看生成了一個隨機名稱的volume。
2.然后,可以在其他容器中使用–volumes-from來掛載dbdata容器中的數(shù)據(jù)卷,例如創(chuàng)建db1和db2兩個容器,并從dbdata容器掛載數(shù)據(jù)卷:
3.然后此時在三個容器中任何一方在/dbdata目錄下的寫入,其他容器中都可以看到。
在圖中,在dbdata容器中創(chuàng)建testfile文件并寫入”dbdata container write!”,然后在db1容器中查看并寫入“db1 container write!”,然后在db2容器中查看并寫入“da2 container write!”,最后回到dbdata容器中查看。
4.然后還可以通過多個–volumes-from來掛載多個數(shù)據(jù)卷,然后還給出了備份和恢復(fù)的方法,網(wǎng)上一搜一大把。
3.為什么不用數(shù)據(jù)卷容器?
在看到許許多多關(guān)于數(shù)據(jù)卷容器的文章,并且都是大同小異。然后我想了想發(fā)現(xiàn)并沒有使用數(shù)據(jù)卷的必要性(或許是我想的不夠周全)。
上面提到數(shù)據(jù)卷容器用來在多個容器中共享數(shù)據(jù),但是在明明可以通過掛載一個相同的本地目錄就能實現(xiàn)該方法。比如說在第一步中創(chuàng)建的my-vol數(shù)據(jù)卷,我可以將其同時掛載到db3和db4容器中。
在圖中,我將my-vol數(shù)據(jù)卷掛載到了db3和db4中,然后在其中能夠找到之前的數(shù)據(jù)文件,并且在db4容器中對testfile文件進(jìn)行寫入操作,在db3中容器中也可以查看。
那么也就是說,我同樣的可以通過掛載一個數(shù)據(jù)卷就可以實現(xiàn)多個容器中的數(shù)據(jù)共享,并且在主機的目錄中添加的文件,在所有的容器中也能夠查看。如果備份的話直接在主機本地將文件夾進(jìn)行拷貝即可,豈不是更方便。
4.為什么使用數(shù)據(jù)卷容器?
但是數(shù)據(jù)卷容器還有一個作用比較不錯,那就是可以用來指定掛載本地目錄,在第一點中我們創(chuàng)建一個名為my-vol的數(shù)據(jù)卷,該數(shù)據(jù)卷在本地存放的目錄為:/var/lib/docker/volumes/my-vol/_data,可以看出這個名字很長不方便操作,可以通過數(shù)據(jù)卷容器來解決該問題。
比如我在主機上創(chuàng)建了一個專門用來存放主機和容器進(jìn)行文件交互的目錄,也就是說以后我想給容器中傳輸什么文件了,我直接將文件拷貝到該目錄下即可:
我在官方文檔中并沒有發(fā)現(xiàn)使用docker volume create 創(chuàng)建數(shù)據(jù)卷時可以指定volume對應(yīng)的本地目錄的命令(或許是我看的不夠多)。
但是我就是想要用/usr/local/datadb 這個目錄該怎么辦?此刻數(shù)據(jù)卷容器的作用就出來了,可以通過創(chuàng)建一個數(shù)據(jù)卷容器,并且將該目錄掛在到數(shù)據(jù)卷容器上即可:
在圖中,我創(chuàng)建了一個所謂的數(shù)據(jù)卷容器,并且使用-v參數(shù),將剛才主機的/usr/local/datadb目錄掛載進(jìn)去,然后在容器中創(chuàng)建文件testfile并寫入“hahahaha”,在主機上進(jìn)行查看。
然后在其他容器創(chuàng)建的時候既可以使用–volumes-from將該數(shù)據(jù)卷容器進(jìn)行掛載,然后想給容器中傳文件的時候直接拷貝到/usr/local/datadb目錄下即可,反過來容器給主機傳文件直接拷貝到容器中的掛載目錄下即可。
讀到這里,這篇“如何用Volume在主機和Docker間進(jìn)行文件傳輸”文章已經(jīng)介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領(lǐng)會,如果想了解更多相關(guān)內(nèi)容的文章,歡迎關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。