這篇“Docker的持久化存儲(chǔ)和數(shù)據(jù)共享是什么”文章的知識(shí)點(diǎn)大部分人都不太理解,所以小編給大家總結(jié)了以下內(nèi)容,內(nèi)容詳細(xì),步驟清晰,具有一定的借鑒價(jià)值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來(lái)看看這篇“Docker的持久化存儲(chǔ)和數(shù)據(jù)共享是什么”文章吧。
成華網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)!從網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站建設(shè)、微信開(kāi)發(fā)、APP開(kāi)發(fā)、成都響應(yīng)式網(wǎng)站建設(shè)公司等網(wǎng)站項(xiàng)目制作,到程序開(kāi)發(fā),運(yùn)營(yíng)維護(hù)。創(chuàng)新互聯(lián)自2013年起到現(xiàn)在10年的時(shí)間,我們擁有了豐富的建站經(jīng)驗(yàn)和運(yùn)維經(jīng)驗(yàn),來(lái)保證我們的工作的順利進(jìn)行。專(zhuān)注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)。
有些容器會(huì)自動(dòng)產(chǎn)生一些數(shù)據(jù),為了不讓數(shù)據(jù)隨著container的消失而消失,保證數(shù)據(jù)的安全性。例如:數(shù)據(jù)庫(kù)容器,數(shù)據(jù)表的表會(huì)產(chǎn)生一些數(shù)據(jù),如果我把container給刪除,數(shù)據(jù)就丟失。為了保證數(shù)據(jù)不丟失,這就有了volume的存在。
data volume 結(jié)構(gòu)圖
docker持久化數(shù)據(jù)的方案
基于本地文件系統(tǒng)的volume。可以再執(zhí)行docker create或docker run時(shí),通過(guò)-v參數(shù)將主機(jī)的目錄作為容器的數(shù)據(jù)卷。這部分功能便是基本的本地文件系統(tǒng)的volume管理。
基于plugin的volume,支持第三方的存儲(chǔ)方案,比如nas,aws
volume的類(lèi)型
受管理的data volume,由docker后臺(tái)自動(dòng)創(chuàng)建。
綁定掛載的volume,具體掛載位置可以由用戶指定。
數(shù)據(jù)持久化之data volume
以官方鏡像MySQL的dockerfile文件為例 。其中dockerfile通過(guò)volume指定了當(dāng)前容器中要備份的文件路徑,但是并沒(méi)有指定說(shuō)要保存到宿主機(jī)的哪個(gè)位置。
volume:映射容器中的文件到本地宿主機(jī)硬盤(pán)中
在我們使用 docker run
啟動(dòng)mysql鏡像容器的時(shí)候,容器會(huì)默認(rèn)在宿主機(jī)生成一個(gè)volume,至于位置在哪,名字是什么,可以通過(guò)如下命令查看
#查看所有volume docker volume ls #刪除指定volume docker volume rm [volume name] #查看volume詳細(xì) docker volume inspect [volume name]
此時(shí)我們刪除容器,發(fā)現(xiàn)volume數(shù)據(jù)卷還在,有保留。
此時(shí)我們會(huì)覺(jué)得這個(gè)data volume name 的名字很長(zhǎng),很不好理解。我們可以通過(guò) -v
如下命令來(lái)指定生成的volume name docker run -d -v mysql:/var/lib/mysql --name mysql mysql5.7
-v
:前參數(shù)是volume name, :后面的是要備份的文件目錄(容器)
此時(shí)我們刪除容器,volume數(shù)據(jù)卷還在,我們用這個(gè)名為mysql的volume作為一個(gè)新容器的數(shù)據(jù)卷,覆蓋它。
docker run -d -v mysql:/var/lib/mysql --name mysql2 mysql5.7
進(jìn)入mysql2容器中,mysql -uroot 進(jìn)入數(shù)據(jù)庫(kù)中,發(fā)現(xiàn)當(dāng)前數(shù)據(jù)庫(kù)數(shù)據(jù)和之前刪除的容器中的數(shù)據(jù)庫(kù)數(shù)據(jù)一樣。
數(shù)據(jù)持久化之bind mounting
和上面data volume不同的是,bind mounting只能通過(guò) docker run -v
方式啟動(dòng),無(wú)法使用dockerfile文件的方式。
運(yùn)行容器的時(shí)候指定本地的一個(gè)文件目錄和容器中的一個(gè)文件目錄的映射,通過(guò)這個(gè)可以做文件數(shù)據(jù)同步,2方無(wú)論哪一方有修改,另一方都會(huì)同步內(nèi)容
docker run -d -v $(pwd):/usr/share/nginx/html -p 80:80 --name nginx nginx
這個(gè)時(shí)候 -v
:前面的參數(shù)是本機(jī)文件路徑, :后面是docker文件目錄(容器)
值得注意的是 ,使用bind mounting方式做數(shù)據(jù)卷的映射時(shí),首次 docker run -v
運(yùn)行,如果本機(jī)的文件夾是沒(méi)有內(nèi)容的,docker容器中的文件夾是有內(nèi)容的,則本機(jī)的會(huì)覆蓋dokcer容器中的,也就是容器中原本有內(nèi)容的也會(huì)沒(méi)有內(nèi)容。
以上就是關(guān)于“Docker的持久化存儲(chǔ)和數(shù)據(jù)共享是什么”這篇文章的內(nèi)容,相信大家都有了一定的了解,希望小編分享的內(nèi)容對(duì)大家有幫助,若想了解更多相關(guān)的知識(shí)內(nèi)容,請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。