一文帶你了解linux中Docker背后的原理
docker輕量,一次封裝到處運行,啟動快,所以很適合做擴縮容、微服務。
一、隔離
vmware
使用supervisor
模擬出硬件,然后在其之上安裝完整的一套操作系統,這套完整的操作系統跑在宿主機操作系統之上,被宿主機操作系統調度,所以較為重量。
而docker
復用宿主機操作系統的內核,作為普通進程調用,使用linux
提供的namespace
隔離技術來實現虛擬化,是一種輕量級虛擬化技術。namespace
表示一個標識符的可見范圍,各namespace互不相干,所以標識符能夠任意定義而不沖突。
linux提供6種namespace:UTS(主機名)、User、Mount(文件系統)、Net、IPC、Pid。有了這幾種名稱空間,會讓進程自身覺得跑在一臺獨立的操作系統上,這是操作系統的欺騙性。
docker
輕量,一次封裝到處運行,啟動快,所以很適合做擴縮容、微服務。
二、網絡
docker
默認會使用bridge網絡模型,即容器中的有veth的一端,另一端veth連接到bridge
網橋上,網橋連接宿主機網絡,使用NAT來實現和外部通信。veth的原理是這樣,通常成對出現,發送給veth一端的包可以被另一端接收到。
docker
還有其他幾種模型,比如沒net,容器中只有環回網絡loopback。聯合net,多個容器使用相同的veth。hostnet,容器直接使用宿主機網絡。
三、鏡像
鏡像是一個可執行的軟件包,包含運行應用程序所需的一切。
docker
的鏡像使用分層結構,就是所謂的“分層存儲,聯合掛載”。
最下面一層是bootfs,包含bootloader
。再往上是根系統鏡像層,再往上是各種鏡像層,除了最上層是可讀寫之外,其余層均為只讀層。所以,如果在頂層鏡像有對下層鏡像數據做修改的話,該數據會COW(copy on write)復制到頂層進行,然后再進行修改。所以,可想而知,這種聯合掛載文件系統的效率不是很高,所以在使用中會用到volume,卷,即脫離于分層存儲的存儲。
到此這篇關于 一文帶你了解Docker背后的原理的文章就介紹到這了,更多相關Docker背后的原理內容請搜索以前的文章或繼續瀏覽下面的相關文章,希望大家以后多多支持!
相關文章:
1. Windows與VMware下的Linux文件共享方式總結2. Linux(CentOS7)使用 RPM 安裝 mysql 8.0.11的教程3. VMware中使用Windows2003和Linux混合運行RIP路由協議(二)4. Linux系統如何配置雙顯卡?5. Linux漏洞掃描工具lynis使用方法解析6. linux系統有哪些7. Linux下IntelliJ IDEA 2017的安裝破解教程8. Golang在Mac、Linux、Windows下如何交叉編譯的實現9. Linux 網管 123 --- 第5章. 組態 X Window 系統 -6.KDE 的10. 淺析Linux之bash反彈shell原理
