一文帶你了解linux中Docker背后的原理
docker輕量,一次封裝到處運(yùn)行,啟動(dòng)快,所以很適合做擴(kuò)縮容、微服務(wù)。
一、隔離
vmware
使用supervisor
模擬出硬件,然后在其之上安裝完整的一套操作系統(tǒng),這套完整的操作系統(tǒng)跑在宿主機(jī)操作系統(tǒng)之上,被宿主機(jī)操作系統(tǒng)調(diào)度,所以較為重量。
而docker
復(fù)用宿主機(jī)操作系統(tǒng)的內(nèi)核,作為普通進(jìn)程調(diào)用,使用linux
提供的namespace
隔離技術(shù)來實(shí)現(xiàn)虛擬化,是一種輕量級(jí)虛擬化技術(shù)。namespace
表示一個(gè)標(biāo)識(shí)符的可見范圍,各namespace互不相干,所以標(biāo)識(shí)符能夠任意定義而不沖突。
linux提供6種namespace:UTS(主機(jī)名)、User、Mount(文件系統(tǒng))、Net、IPC、Pid。有了這幾種名稱空間,會(huì)讓進(jìn)程自身覺得跑在一臺(tái)獨(dú)立的操作系統(tǒng)上,這是操作系統(tǒng)的欺騙性。
docker
輕量,一次封裝到處運(yùn)行,啟動(dòng)快,所以很適合做擴(kuò)縮容、微服務(wù)。
二、網(wǎng)絡(luò)
docker
默認(rèn)會(huì)使用bridge網(wǎng)絡(luò)模型,即容器中的有veth的一端,另一端veth連接到bridge
網(wǎng)橋上,網(wǎng)橋連接宿主機(jī)網(wǎng)絡(luò),使用NAT來實(shí)現(xiàn)和外部通信。veth的原理是這樣,通常成對(duì)出現(xiàn),發(fā)送給veth一端的包可以被另一端接收到。
docker
還有其他幾種模型,比如沒net,容器中只有環(huán)回網(wǎng)絡(luò)loopback。聯(lián)合net,多個(gè)容器使用相同的veth。hostnet,容器直接使用宿主機(jī)網(wǎng)絡(luò)。
三、鏡像
鏡像是一個(gè)可執(zhí)行的軟件包,包含運(yùn)行應(yīng)用程序所需的一切。
docker
的鏡像使用分層結(jié)構(gòu),就是所謂的“分層存儲(chǔ),聯(lián)合掛載”。
最下面一層是bootfs,包含bootloader
。再往上是根系統(tǒng)鏡像層,再往上是各種鏡像層,除了最上層是可讀寫之外,其余層均為只讀層。所以,如果在頂層鏡像有對(duì)下層鏡像數(shù)據(jù)做修改的話,該數(shù)據(jù)會(huì)COW(copy on write)復(fù)制到頂層進(jìn)行,然后再進(jìn)行修改。所以,可想而知,這種聯(lián)合掛載文件系統(tǒng)的效率不是很高,所以在使用中會(huì)用到volume,卷,即脫離于分層存儲(chǔ)的存儲(chǔ)。
到此這篇關(guān)于 一文帶你了解Docker背后的原理的文章就介紹到這了,更多相關(guān)Docker背后的原理內(nèi)容請(qǐng)搜索本站以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持本站!
版權(quán)聲明:本站文章來源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請(qǐng)保持原文完整并注明來源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非www.sddonglingsh.com所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學(xué)習(xí)參考,不代表本站立場(chǎng),如有內(nèi)容涉嫌侵權(quán),請(qǐng)聯(lián)系alex-e#qq.com處理。