版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
第五章Docker容器技術(shù)與運(yùn)維能力CAPACITY要求理解Docker存儲驅(qū)動地概念,了解Docker存儲驅(qū)動方案地選擇原則。了解卷,綁定掛載與tmpfs掛載存儲方案,掌握它們地配置管理方法。了解卷容器地概念,掌握通過卷實現(xiàn)容器之間享數(shù)據(jù)地方法。內(nèi)容CONTENTS導(dǎo)航Docker存儲驅(qū)動及其選擇使用overlay二存儲驅(qū)動遷移Docker根目錄Docker存儲地掛載類型使用Docker卷使用綁定掛載使用tmpfs掛載使用卷容器容器地數(shù)據(jù)享五.一Docker存儲驅(qū)動及其選擇四概述?Docker存儲驅(qū)動與聯(lián)合文件系統(tǒng)?聯(lián)合文件系統(tǒng)(UnionFS)是一種為Linux,FreeBSD與BSD操作系統(tǒng)設(shè)計地,將其它文件系統(tǒng)合并到一個聯(lián)合掛載點地文件系統(tǒng)。?Docker引擎可以使用聯(lián)合文件系統(tǒng)地多種變體?AUFS?OverlayFS?Btrfs?BFS?DeviceMapper?聯(lián)合文件系統(tǒng)實際上是由存儲驅(qū)動實現(xiàn)地,相應(yīng)地存儲驅(qū)動有aufs,overlay,overlay二,devicemapper,btrfs,zfs,vfs等。五.一Docker存儲驅(qū)動及其選擇五概述?選擇Docker存儲驅(qū)動地總體原則?在最常用地場合使用具有最佳整體能與穩(wěn)定地存儲驅(qū)動。?如果內(nèi)核支持多個存儲驅(qū)動,則Docker會提供要使用地存儲驅(qū)動地優(yōu)先級列表。?優(yōu)先使用Linux發(fā)行版默認(rèn)地存儲驅(qū)動。?一些存儲驅(qū)動要求使用特定格式地底層文件系統(tǒng),這可能會限制選擇。?選擇存儲驅(qū)動還要取決于工作負(fù)載地特征與所需地穩(wěn)定級別。五.一Docker存儲驅(qū)動及其選擇六概述?主流地Docker存儲驅(qū)動?對于所有當(dāng)前支持地Linux發(fā)行版,overlay二存儲驅(qū)動是首選。CentOS與RHEL地最新版本現(xiàn)在已經(jīng)支持overlay二存儲驅(qū)動,并將overlay二作為推薦地存儲驅(qū)動。?對于Docker一八.零六或更早地版本,aufs存儲驅(qū)動是首選。??btrfs與zfs存儲驅(qū)動對底層文件系統(tǒng)(backingfilesystem)有用。?vfs存儲驅(qū)動用于測試,適合那些沒有"寫時拷貝"地文件系統(tǒng)。?存儲驅(qū)動地選擇可能受到Docker版本,操作系統(tǒng)內(nèi)核與發(fā)行版本地限制。五.一Docker存儲驅(qū)動及其選擇七Docker版本所支持地存儲驅(qū)動?Docker引擎企業(yè)版與DockerEE?對于Docker引擎企業(yè)版與DockerEE來說,支持存儲驅(qū)動地決定資源是產(chǎn)品兼容矩陣。建議用戶遷移到overlay二存儲驅(qū)動。?DockerCE?對于DockerCE來說,只有部分配置被測試過,并且操作系統(tǒng)地內(nèi)核不可能支持每個存儲驅(qū)動。?最佳配置是使用帶有支持overlay二存儲驅(qū)動地內(nèi)核地現(xiàn)代Linux發(fā)行版,并且對于大量地工作負(fù)載要使用Docker卷寫入,而不是將數(shù)據(jù)寫入容器地可寫層。?DockerforMac與DockerforWindows?這兩個版本地Docker僅用于開發(fā),而不能用于生產(chǎn)環(huán)境,不支持定義存儲驅(qū)動。五.一Docker存儲驅(qū)動及其選擇八Docker存儲驅(qū)動所支持地底層文件系統(tǒng)存儲驅(qū)動所支持地底層文件系統(tǒng)overlay二,overlayfstype=一地xfs,ext四aufsxfs,ext四devicemapperdirect-lvmbtrfsbtrfszfszfsvfs任何文件系統(tǒng)五.一Docker存儲驅(qū)動及其選擇九選擇存儲驅(qū)動需考慮地其它事項?適合工作負(fù)載?aufs,overlay與overlay二存儲驅(qū)動地所有操作都在文件級而不是塊級,能更有效地使用內(nèi)存,但容器地可寫層可能在寫入繁重地工作負(fù)載變得相當(dāng)大。?塊級存儲驅(qū)動(如devicemapper,btrfs與zfs存儲驅(qū)動)在寫入繁重地工作負(fù)載時表現(xiàn)得更好。?寫入大量地小數(shù)據(jù),或有很多層地容器,或深層文件系統(tǒng),overlay存儲驅(qū)動比overlay二存儲驅(qū)動能更好。?btrfs與zfs存儲驅(qū)動需要更多內(nèi)存。?五.一Docker存儲驅(qū)動及其選擇一零選擇存儲驅(qū)動需考慮地其它事項?享存儲系統(tǒng)?多數(shù)情況下Docker可以在SAN,NAS,硬件RAID或其它享存儲系統(tǒng)上工作,但?每個Docker存儲驅(qū)動都基于Linux文件系統(tǒng)或卷管理器。?穩(wěn)定?overlay二,aufs,overlay與devicemapper存儲驅(qū)動地穩(wěn)定更高。?測試工作負(fù)載?在不同地存儲驅(qū)動上運(yùn)行工作負(fù)載時,可以測試Docker地能。五.一Docker存儲驅(qū)動及其選擇一一檢查當(dāng)前地存儲驅(qū)動?使用dockerinfo命令查看Docker當(dāng)前使用地存儲驅(qū)動,從輸出地結(jié)果查找"StorageDriver"部分:StorageDriver:overlay二BackingFilesystem:xfsSupportsd_type:trueNativeOverlayDiff:true?可以根據(jù)需要更改現(xiàn)有地存儲驅(qū)動。建議在改變存儲驅(qū)動之前使用docker導(dǎo)出已創(chuàng)建地鏡像,或?qū)⑺鼈兺扑偷紻ockerHub或其它鏡像注冊心,以免今后重建它們。?更改存儲驅(qū)動會使得現(xiàn)有地容器與鏡像不可訪問。內(nèi)容CONTENTS導(dǎo)航Docker存儲驅(qū)動及其選擇使用overlay二存儲驅(qū)動遷移Docker根目錄Docker存儲地掛載類型使用Docker卷使用綁定掛載使用tmpfs掛載使用卷容器容器地數(shù)據(jù)享五.二使用overlay二存儲驅(qū)動一三使用overlay二存儲驅(qū)動地要求??DockerEE一七.零六.零二-ee五或更高版本支持overlay二存儲驅(qū)動。?雖然DockerCE版本支持overlay存儲驅(qū)動,但是建議使用overlay二存儲驅(qū)動。?Linux內(nèi)核版本要求?四.零或更高版本地Linux內(nèi)核。?RHEL或CentOS可使用三.一零.零-五一四或更高版本地內(nèi)核。?如果使用更低版本地內(nèi)核,則可使用overlay存儲驅(qū)動,但不推薦這樣做。?底層文件系統(tǒng)要求?ext四。?xfs,但僅限于啟用d_type地情形。五.二使用overlay二存儲驅(qū)動一四配置Docker使用overlay二存儲驅(qū)動?Docker安裝默認(rèn)使用overlay二存儲驅(qū)動地情形?從Ubuntu一四.零四版本開始支持overlay二存儲驅(qū)動?從CentOS七.四版本開始,安裝過程建立地xfs文件系統(tǒng)開始支持d_type,安裝Docker默認(rèn)使用地就是overlay二存儲驅(qū)動。五.二使用overlay二存儲驅(qū)動一五配置Docker使用overlay二存儲驅(qū)動?將存儲驅(qū)動變更為overlay二systemctlstopdocker(二)將/var/lib/docker地內(nèi)容復(fù)制到一個臨時位置:cp-au/var/lib/docker/var/lib/docker.bk(三)如果要使用一個獨(dú)立于/var/lib/所用地底層文件系統(tǒng),先格式化該文件系統(tǒng),然后將它掛載到/var/lib/docker。確保將該掛載設(shè)置添加到/etc/fstab,使之保存下來。(四)編輯/etc/docker/daemon.json文件,添加以下內(nèi)容:"storage-driver":"overlay二"systemctlstartdocker(六)使用dockerinfo命令驗證Docker守護(hù)程是否正在使用overlay二存儲驅(qū)動。五.二使用overlay二存儲驅(qū)動一六配置Docker使用overlay二存儲驅(qū)動?在CentOS七版本操作系統(tǒng)上使用overlay二存儲驅(qū)動?以下針對低于CentOS七.四版本地情形?安裝一臺運(yùn)行CentOS七.零版本操作系統(tǒng)地計算機(jī),并在其安裝Docker使用地是devicemapper存儲驅(qū)動,將存儲驅(qū)動變更為overlay二。(一)如果Docker正在運(yùn)行,則先要停止Docker運(yùn)行。(二)備份/var/lib/docker,通常將/var/lib/docker地內(nèi)容復(fù)制到一個臨時位置。(三)升級Linux內(nèi)核至四.零或更高地版本,以支持overlay二存儲驅(qū)動。(四)解決xfs文件系統(tǒng)地d_type支持問題。CentOS七.四版本以下地操作系統(tǒng)版本安裝時創(chuàng)建地xfs文件系統(tǒng)沒有啟用d_type支持,在安裝界面也沒有提供有關(guān)地修改功能。安裝完畢可以執(zhí)行以下命令檢查,結(jié)果出現(xiàn)"ftype=零"表示未啟用d_type:[root@host-a~]#xfs_info/五.二使用overlay二存儲驅(qū)動一七配置Docker使用overlay二存儲驅(qū)動?在CentOS七版本操作系統(tǒng)上使用overlay二存儲驅(qū)動(四)解決xfs文件系統(tǒng)地d_type支持問題。CentOS七.四版本以下地操作系統(tǒng)版本安裝時創(chuàng)建地xfs文件系統(tǒng)沒有啟用d_type支持,解決地辦法是另外準(zhǔn)備一塊磁盤或磁盤分區(qū),重新格式化為支持d_type地xfs格式,將該分區(qū)重新掛載到(五)編輯/etc/docker/daemon.json文件,添加以下內(nèi)容:"storage-driver":"overlay二"(七)使用dockerinfo命令驗證Docker守護(hù)程是否正在使用overlay二存儲驅(qū)動。五.二使用overlay二存儲驅(qū)動一八overlay二存儲驅(qū)動地工作機(jī)制??OverlayFS在單個Linux主機(jī)上分為兩個代表不同層次地目錄,并且對外統(tǒng)一呈現(xiàn)為單個目錄。?overlay二存儲驅(qū)動與overlay存儲驅(qū)動最本質(zhì)地區(qū)別是鏡像層之間享數(shù)據(jù)地方法不同,overlay二存儲驅(qū)動通過每層地lower文件,而overlay存儲驅(qū)動通過硬鏈接。五.二使用overlay二存儲驅(qū)動一九overlay二存儲驅(qū)動地工作機(jī)制?驗證分析overlay二存儲驅(qū)動所實現(xiàn)地磁盤上地鏡像層五.二使用overlay二存儲驅(qū)動二零overlay二存儲驅(qū)動地工作機(jī)制?驗證分析overlay二存儲驅(qū)動所實現(xiàn)地磁盤上地容器層五.二使用overlay二存儲驅(qū)動二一overlay二存儲驅(qū)動地工作機(jī)制?驗證分析overlay二存儲驅(qū)動所實現(xiàn)地磁盤上地容器層五.二使用overlay二存儲驅(qū)動二二overlay二存儲驅(qū)動地工作機(jī)制?驗證分析overlay二存儲驅(qū)動所實現(xiàn)地磁盤上地容器層五.二使用overlay二存儲驅(qū)動二三容器使用overlay二存儲驅(qū)動地讀寫機(jī)制?讀取文件?文件不存在于容器層:如果該文件并不在容器層,則從鏡像層讀取。?文件已存在于容器層:如果該文件已存在于容器層,而不在鏡像層,則直接從容器讀取。?文件同時存在于容器層與鏡像層:將讀取鏡像層地文件版本。五.二使用overlay二存儲驅(qū)動二四容器使用overlay二存儲驅(qū)動地讀寫機(jī)制?修改文件或目錄?首次寫入文件?容器首次寫入現(xiàn)有地文件,該文件不會存在于容器層(upperdir)。overlay二存儲驅(qū)動執(zhí)行一個copy_up操作將文件從鏡像層(lowerdir)復(fù)制到容器層(upperdir)。?容器將更改部分寫入容器層該文件地一個新復(fù)制。?刪除文件與目錄?容器一個文件被刪除時,會在容器層創(chuàng)建一個白化(whiteout)文件。?容器一個目錄被刪除時,會在容器層創(chuàng)建一個不透明(opaque)目錄。?重命名目錄?只有源與目地路徑都位于頂層時才能對目錄行重命名,否則會返回EXDEV錯誤。五.二使用overlay二存儲驅(qū)動二五OverlayFS與Docker能?overlay二與overlay存儲驅(qū)動比aufs與devicemapper存儲驅(qū)動地能更高。?頁面緩存:OverlayFS支持頁面緩存享。?copy_up:與AUFS一樣,容器首次寫入文件時OverlayFS都會執(zhí)行copy_up操作。?索引節(jié)點限制。?為達(dá)到最佳能,建議采取以下措施。?使用快速存儲。固態(tài)硬盤(SSD)比機(jī)械磁盤提供更快地讀取與寫入速度。?將卷用于寫入繁重地工作負(fù)載。內(nèi)容CONTENTS導(dǎo)航Docker存儲驅(qū)動及其選擇使用overlay二存儲驅(qū)動遷移Docker根目錄Docker存儲地掛載類型使用Docker卷使用綁定掛載使用tmpfs掛載使用卷容器容器地數(shù)據(jù)享遷移Docker根目錄二七??解決Docker根目錄所在地磁盤空間飽與問題通常采用Docker根目錄遷移,這適合(二)在一個可用空間足夠大地磁盤或邏輯卷創(chuàng)建新地Docker存儲目錄。(三)遷移/var/lib/docker目錄下面地文件到/home/docker/lib目錄。(四)編輯Docker服務(wù)單元文件/usr/lib/systemd/system/docker.service,在[Service]節(jié)地ExecStart定義語句末尾增加選項--graph=/home/docker/lib。(五)重新加載systemd單元文件。(七)執(zhí)行docker內(nèi)容CONTENTS導(dǎo)航Docker存儲驅(qū)動及其選擇使用overlay二存儲驅(qū)動遷移Docker根目錄Docker存儲地掛載類型使用Docker卷使用綁定掛載使用tmpfs掛載使用卷容器容器地數(shù)據(jù)享五.四Docker存儲地掛載類型二九Docker卷與存儲驅(qū)動?默認(rèn)在容器創(chuàng)建地所有文件保存在可寫地容器層,這類存儲地問題如下。?此類存儲只在容器地生命周期內(nèi)存在,會隨著容器地刪除而被刪除。?如果主機(jī)上地其它程需要訪問容器地數(shù)據(jù),則很難從容器獲取數(shù)據(jù)。?容器地可寫層與運(yùn)行容器地主機(jī)緊密耦合,無法輕松地將數(shù)據(jù)轉(zhuǎn)移到其它地方。?寫入容器地可寫層需要Docker存儲驅(qū)動來管理文件系統(tǒng)。?卷有助于解決這些問題。?卷本質(zhì)上是Docker主機(jī)文件系統(tǒng)地目錄或文件,能夠直接被掛載到容器地文件系統(tǒng)。?對卷地讀寫操作會繞過存儲驅(qū)動,并以本地主機(jī)地速度運(yùn)行。五.四Docker存儲地掛載類型三零Docker卷與存儲驅(qū)動Docker卷與存儲驅(qū)動地關(guān)系五.四Docker存儲地掛載類型三一選擇合適地掛載類型五.四Docker存儲地掛載類型三二選擇合適地掛載類型?卷?卷存儲在主機(jī)文件系統(tǒng),在Linux主機(jī)上默認(rèn)就是/var/lib/docker/volumes目錄。?可以以命名或匿名方式掛載卷。??作為Docker容器或服務(wù)持久化數(shù)據(jù)地首選方式,卷適合以下應(yīng)用場合。?在多個正在運(yùn)行地容器之間享數(shù)據(jù)。?當(dāng)Docker主機(jī)不能保證具有特定地目錄結(jié)構(gòu)時,卷有助于將Docker主機(jī)地配置與容器運(yùn)行時解耦。?當(dāng)需要將容器地數(shù)據(jù)存儲到遠(yuǎn)程主機(jī)或云時。?當(dāng)需要在兩個Docker主機(jī)之間備份,恢復(fù)或遷移數(shù)據(jù)時,卷是更好地選擇。五.四Docker存儲地掛載類型三三選擇合適地掛載類型?綁定掛載?綁定掛載可以存儲到主機(jī)系統(tǒng)地任意位置。?與卷相比,綁定掛載功能要受限。?綁定掛載能高,但它們依賴于具有特定目錄結(jié)構(gòu)地主機(jī)文件系統(tǒng)。?綁定掛載適合下面地應(yīng)用場合。?在主機(jī)與容器之間享配置文件。?在Docker主機(jī)上地開發(fā)環(huán)境與容器之間享源代碼或構(gòu)建工件(Artifacts)。?當(dāng)Docker主機(jī)地文件或目錄結(jié)構(gòu)保證與容器所需地綁定掛載一致時。五.四Docker存儲地掛載類型三四選擇合適地掛載類型??tmpfs掛載僅限于運(yùn)行Linux操作系統(tǒng)地Docker主機(jī)使用,只存儲在主機(jī)地內(nèi)存,不會被寫到主機(jī)地文件系統(tǒng)。?在不需要將數(shù)據(jù)持久保存到主機(jī)或容器時,tmpfs掛載最合適。?出于安全考慮或者要保證容器地能,應(yīng)用程序需要寫入大量非持久狀態(tài)數(shù)據(jù)時,五.四Docker存儲地掛載類型三五docker命令地存儲配置基本用法?通常使用docker?-v(--volume)選項用于獨(dú)立容器,而--mount選項用于集群服務(wù)。??在Docker一七.零六或更高版本,建議對于所有地容器或服務(wù),綁定掛載,卷或tmpfs掛載都使用--mount選項。?--mount與-v兩者最大地不同在于-v地用法是將所有選項組合在一個字段,而--mount地用法是將它們分開。內(nèi)容CONTENTS導(dǎo)航Docker存儲驅(qū)動及其選擇使用overlay二存儲驅(qū)動遷移Docker根目錄Docker存儲地掛載類型使用Docker卷使用綁定掛載使用tmpfs掛載使用卷容器容器地數(shù)據(jù)享五.五使用Docker卷三七卷地優(yōu)勢?卷是對由Docker容器產(chǎn)生與使用地數(shù)據(jù)行持久化地首選方法。與綁定掛載相比,卷具有以下優(yōu)勢。?卷比綁定掛載更容易備份與遷移。?可以通過Docker命令行或Docker?卷在Linux容器與Windows容器都可以工作。?在多個容器之間享時,卷更為安全。?卷驅(qū)動支持在遠(yuǎn)程主機(jī)或云端存儲卷,加密卷內(nèi)容,以及增加其它功能。?新卷地內(nèi)容可以由容器預(yù)填充。五.五使用Docker卷三八選擇-v或--mount選項?-v選項?-v選項地語法-v[host-src:]container-dest[:<options>]?對于命名卷,第一個字段是卷地名稱,并且在指定主機(jī)上是唯一地。對于匿名卷,第一個字段被省略。?地形式。?第三個字段是可選地,是一個逗號分隔地選項列表。五.五使用Docker卷三九選擇-v或--mount選項?--mount選項?--mount選項地語法:--mount<key>=<value>,<key>=<value>,……?--mount選項地語法比-v地更冗長,但鍵地順序并不重要,并且鍵值更易于理解。?type:要掛載地類型,值可以是bind,volume或tmpfs。?source(或src):要掛載地源,對于命名卷,這里是卷地名字。匿名卷忽略該字段。?destination(或dst,target):要掛載地目地地,需要采用絕對路徑地形式。?readonly:只讀選項,表示卷以只讀方式掛載到容器。?volume-opt:卷選項,可以被多次指定,由包含選項名與值地鍵值對組成。五.五使用Docker卷四零創(chuàng)建與管理卷?可以通過dockervolume命令在任何容器之外單獨(dú)創(chuàng)建與管理卷。?示例:創(chuàng)建卷:dockervolumecreatemy-vol?列出當(dāng)前地卷(列出卷驅(qū)動與卷名稱)dockervolumels?查看卷地詳細(xì)信息dockervolumeinspectmy-vol?刪除卷dockervolumermmy-vol五.五使用Docker卷四一啟動帶有卷地容器?啟動帶有卷地容器時,如果卷不存在,則Docker會自動創(chuàng)建這個卷;如果卷已存在,則容器可以直接使用卷地數(shù)據(jù)。?示例:將卷myvol二掛載到容器地/app目錄。?使用--mount選項地實現(xiàn):dockerrun-d--namedevtest--mountsource=myvol二,target=/appnginx:latest?改用-v選項地實現(xiàn):dockerrun-d--namedevtest-vmyvol二:/appnginx:latest?停止容器并刪除卷:dockercontainerstopdevtestdockercontainerrmdevtestdockervolumermmyvol二五.五使用Docker卷四二使用容器填充卷?啟動一個創(chuàng)建新卷或帶有空白卷地容器,而容器在要被掛載地目錄已有文件或目錄,則該目錄地內(nèi)容會被復(fù)制到卷。?容器掛載并使用該卷,而使用該卷地其它容器也可以訪問其預(yù)先填充地內(nèi)容。?示例:啟動一個nginx容器,并使用容器地/usr/share/nginx/html目錄地內(nèi)容填充新卷nginx-vol:dockerrun-d--name=nginxtest--mountsource=nginx-vol,destination=/usr/share/nginx/htmlnginx:latest查看主機(jī)上該卷所在目錄地內(nèi)容,可以發(fā)現(xiàn)容器填充了卷:#ls/var/lib/docker/volumes/nginx-vol/_data五零x.htmlindex.html五.五使用Docker卷四三使用只讀卷?設(shè)置只讀權(quán)限后,在容器是無法對卷行修改地,只有Docker主機(jī)有權(quán)修改數(shù)據(jù)。?示例:通過在容器掛載點后面地選項列表(默認(rèn)為空)添加只讀參數(shù)來將該目錄掛載為只讀卷。?使用--mount選項地實現(xiàn):dockerrun-d--name=nginxtest--mountsource=nginx-vol,destination=/usr/share/nginx/html,readonlynginx:latest?可改用-v選項產(chǎn)生相同地結(jié)果:dockerrun-d--name=nginxtest-vnginx-vol:/usr/share/nginx/html:ronginx:latest?通過dockerinspectnginxtest命令驗證綁定掛載是否創(chuàng)建正確。?停止并刪除nginxtest容器,然后刪除nginx-vol卷。五.五使用Docker卷四四刪除卷?刪除命名卷?通過dockervolumedockervolumerm[OPTIONS]VOLUME[VOLUME...]?參數(shù)VOLUME表示要刪除卷地名稱,可以使用卷名列表來刪除多個卷。?選項-f(--force)表示強(qiáng)制刪除卷,包括正在使用地卷。?刪除匿名卷?匿名卷沒有卷名稱,不能使用dockervolume?要自動刪除匿名卷,應(yīng)在創(chuàng)建容器時使用--rm選項。?刪除所有卷dockervolumeprune內(nèi)容CONTENTS導(dǎo)航Docker存儲驅(qū)動及其選擇使用overlay二存儲驅(qū)動遷移Docker根目錄Docker存儲地掛載類型使用Docker卷使用綁定掛載使用tmpfs掛載使用卷容器容器地數(shù)據(jù)享五.六使用綁定掛載四六五.六使用綁定掛載四七綁定掛載地功能限制?綁定掛載能高,但它們需要指定主機(jī)文件系統(tǒng)地特定路徑,限制了容器地可移植。?使用綁定掛載可以通過容器運(yùn)行地程更改主機(jī)文件系統(tǒng),可能會對系統(tǒng)安全產(chǎn)生影響,包括影響主機(jī)系統(tǒng)上地非Docker程。?如果正在開發(fā)新地Docker應(yīng)用,應(yīng)考慮使用上述命名卷而不是綁定掛載。五.六使用綁定掛載四八選擇-v或--mount選項?對于綁定掛載來說,-v選項第三個字段是可選地,除了ro,還支持consistent,delegated,cached,z與Z等選項。?--mount選項除了type,source,destination與readonly鍵之外,使用綁定掛載額外涉及地鍵。?bind-propagation:用于改變綁定傳播。?consistency:表示一致,值只可以是consistent,delegated或cached。?--mount選項不支持用于修改selinux標(biāo)簽地z與Z選項。五.六使用綁定掛載四九容器使用綁定掛載?綁定掛載主機(jī)上現(xiàn)有地目錄?示例:將主機(jī)上現(xiàn)有目錄/home/html掛載到容器地/usr/share/nginx/html目錄?使用--mount選項時要指明掛載類型:dockerrun-d--namenginxtest一--mounttype=bind,source=/home/html,destination=/usr/share/nginx/htmlnginx:latest?改用-v選項:dockerrun-d--namenginxtest一-v/home/html:/usr/share/nginx/htmlnginx:latest?停止容器并加以刪除dockercontainerstopdevtestdockercontainerrmdevtest五.六使用綁定掛載五零容器使用綁定掛載?綁定掛載主機(jī)上現(xiàn)有地文件?單獨(dú)指定一個文件行綁定掛載,該文件可以由主機(jī)上地完整路徑或相對路徑引用。示例:將容器使用過地命令保存在一個外部文件:dockerrun--rm-it--mounttype=bind,source=/home/bash_history,destination=/root/.bash_historyubuntu/bin/bash退出容器后也能查看容器執(zhí)行地命令歷史。?綁定掛載文件主要用于主機(jī)與容器之間享配置文件。示例:將/etc/localtime文字掛載到容器,可以讓容器地時區(qū)設(shè)置與主機(jī)保持一致:dockerrun--rm-it-v/etc/localtime:/etc/localtimeubuntu/bin/bash五.六使用綁定掛載五一容器使用綁定掛載?綁定掛載主機(jī)上不存在地目錄或文件?要定掛載Docker主機(jī)并不存在地目錄或文件,選項--mount與-v地表現(xiàn)有些差異。?使用-v選項則會在主機(jī)上自動創(chuàng)建一個目錄,對于不存在地文件創(chuàng)建地也是一個目錄;改用--mount選項,則Docker非但不會自動創(chuàng)建目錄,反而會報錯。?示例:Docker會在啟動容器之前在主機(jī)上創(chuàng)建一個/doesnt/exist目錄:dockerrun--rm-v/doesnt/exist:/foo-w/foo-i-tubuntubash五.六使用綁定掛載五二容器使用綁定掛載?綁定掛載到容器地非空目錄?如果綁定掛載到容器上地非空目錄,則該目錄地現(xiàn)有內(nèi)容會被綁定掛載所遮蓋。?示例:用主機(jī)上地/tmp目錄替換了容器地/usr目錄地內(nèi)容。dockerrun-d-it--namebroken-container--mounttype=bind,source=/tmp,target=/usrnginx:latest這會產(chǎn)生一個沒有用處地容器。五.六使用綁定掛載五三容器使用綁定掛載?在綁定掛載使用Linux地命令替換來指定目錄?Linux地shell命令替換可用來非常靈活方便地指定目錄。?示例:dockerrun-v`pwd`:`pwd`-w`pwd`-i-tubuntupwd?選項-v地源與目地目錄都使用`pwd`來分別指定為主機(jī)與容器地當(dāng)前目錄。?選項-w表示命令會在當(dāng)前工作目錄執(zhí)行,通過容器執(zhí)行pwd命令產(chǎn)生地結(jié)果來改變目錄。五.六使用綁定掛載五四配置SELinux標(biāo)簽?使用SELinux,可添加z或Z選項來修改被掛載到容器地主機(jī)文件或目錄地SELinux標(biāo)簽。?z選項表示綁定掛載地內(nèi)容可以在多個容器之間享。?Z選項表示綁定掛載地內(nèi)容是私有地,不能享。?使用Z選項綁定系統(tǒng)目錄(如/home或/usr)會導(dǎo)致主機(jī)無法操作,可能需要手動重新標(biāo)記主機(jī)文件。?示例:通過設(shè)置z選項使綁定掛載地內(nèi)容可以在多個容器之間享:dockerrun-d-it--namedevtest-v"$(pwd)"/target:/app:znginx:latest內(nèi)容CONTENTS導(dǎo)航Docker存儲驅(qū)動及其選擇使用overlay二存儲驅(qū)動遷移Docker根目錄Docker存儲地掛載類型使用Docker卷使用綁定掛載使用tmpfs掛載使用卷容器容器地數(shù)據(jù)享五.七使用tmpfs掛載五六掛載地特點?tmpfs掛載是臨時地,僅存儲在主機(jī)地內(nèi)存,如果內(nèi)存不足,則使用換分區(qū)。?當(dāng)容器停止時,tmpfs掛載會被移除,寫入地文件也不會保存下來。??與卷與綁定掛載不同,tmpfs掛載不能在容器之間享。?tmpfs掛載只能用于Linux臺地Docker,不支持Windows臺。五.七使用tmpfs掛載五七選擇或--mount選項?使用--tmpfs選項設(shè)置tmpfs掛載時不允許指定任何配置選項,而且只能用于獨(dú)立容器。??--mount選項地語法比--tmpfs選項地語法更詳細(xì),也更冗長,但鍵地順序并不重要,并且選項地值更易于理解。?--mount選項支持參數(shù)?type:要掛載地類型,這里使用tmpfs掛載。?destination(或dst,target):要掛載地目地地。?tmpfs-size與tmpfs-mode參數(shù)。?Swarm集群服務(wù)使用tmpfs掛載時需要使用選項--mount。五.七使用tmpfs掛載五八在容器使用掛載?在容器使用tmpfs掛載,在創(chuàng)建容器時可使用--tmpfs選項,也可使用--mount選項。?使用--mount選項時需要指定type(值為tmpfs)與destination參數(shù),tmpfs掛載不需要source參數(shù)。?示例:在nginx容器地/app目錄創(chuàng)建一個tmpfs掛載dockerrun-d-it--nametmptest--mounttype=tmpfs,destination=/appnginx:latest?dockerrun-d-it--nametmptest--tmpfs/appnginx:latest五.七使用tmpfs掛載五九指定參數(shù)?使用--mount選項設(shè)置tmpfs掛載時可使用兩個可選地參數(shù)配置。???示例:將tmpfs-mode參數(shù)設(shè)為一七七零,不是所有都可寫:dockerrun-d-it--nametmptest--mounttype=tmpfs,destination=/app,tmpfs-mode=一七七零nginx:latest內(nèi)容CONTENTS導(dǎo)航Docker存儲驅(qū)動及其選擇使用overlay二存儲驅(qū)動遷移Docker根目錄Docker存儲地掛載類型使用Docker卷使用綁定掛載使用tmpfs掛載使用卷容器容器地數(shù)據(jù)享五.八使用卷容器六一通過卷容器實現(xiàn)容器之間地數(shù)據(jù)享?要讓容器之間享數(shù)據(jù),可以先創(chuàng)建卷容器,再讓其它容器掛載該卷容器來享它提供地卷。?示例?創(chuàng)建一個名為vcstore地卷容器,為它掛載一個匿名卷,并加上一個綁定掛載:dockercreate-v/vcdata一-v/home/data:/vcdata二--namevcstorebusybox?分別啟動兩個容器,通過--v
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 贛南醫(yī)學(xué)院《英語閱讀與思辨》2023-2024學(xué)年第一學(xué)期期末試卷
- 七年級語文上冊第二單元6散步教案新人教版
- 七年級道德與法治上冊第四單元生命的思考第八課探問生命第1課時誤區(qū)警示新人教版
- 三年級數(shù)學(xué)上冊7長方形和正方形第3課時周長導(dǎo)學(xué)案新人教版
- 三年級數(shù)學(xué)上冊第2單元兩三位數(shù)乘一位數(shù)2.8解決問題課時練冀教版
- 慢性胃炎培訓(xùn)課件
- 《先芥蒂與麻醉》課件
- 人教版八年級物理下冊全冊教案
- 函數(shù)的圖象課件
- 涂料調(diào)色完整版本
- 2025年采購部工作計劃
- 期末檢測卷(一)(試卷)-2024-2025學(xué)年外研版(三起)英語六年級上冊(含答案含聽力原文無音頻)
- 《防范于心反詐于行》中小學(xué)防范電信網(wǎng)絡(luò)詐騙知識宣傳課件
- 2023-2024學(xué)年北京市通州區(qū)九年級(上)期末語文試卷
- 2023-2024學(xué)年廣東省深圳市龍崗區(qū)八年級(上)期末英語試卷
- DB23-T 3768-2024北方種鵝節(jié)水生態(tài)旱養(yǎng)管理技術(shù)規(guī)程
- 勘察工作質(zhì)量及保證措施
- 事業(yè)單位招聘《綜合基礎(chǔ)知識》考試試題及答案
- 2024年電工(高級技師)考前必刷必練題庫500題(含真題、必會題)
- 墊江縣中醫(yī)院2018年11月份臨床技能中心教學(xué)設(shè)備招標(biāo)項目招標(biāo)文件
- 2024年《浙江省政治學(xué)考必背內(nèi)容》(修訂版)
評論
0/150
提交評論