服務(wù)器
有些容器會(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的存在。
創(chuàng)新互聯(lián)建站堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:網(wǎng)站設(shè)計(jì)、成都做網(wǎng)站、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時(shí)代的彌勒網(wǎng)站設(shè)計(jì)、移動(dòng)媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!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,awsVolume的類型
受管理的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ù)卷還在,有保留。
-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ù)一樣。
和上面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)容。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。
分享文章:詳解Docker的持久化存儲(chǔ)和數(shù)據(jù)共享
網(wǎng)站網(wǎng)址:http://www.rwnh.cn/article18/cgipdp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站排名、手機(jī)網(wǎng)站建設(shè)、網(wǎng)站收錄、外貿(mào)建站、網(wǎng)站設(shè)計(jì)、企業(yè)建站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容
營(yíng)銷型網(wǎng)站建設(shè)知識(shí)