1. 程式人生 > >dockerToolbox和docker for windows的區別

dockerToolbox和docker for windows的區別

前言:

我們先來補充一下關於hyper-v 虛擬機器與virtualbox和VMware的知識

一:VMware工作站(VMware Workstation)是VMware公司銷售的商業軟體產品之一。該工作站軟體包含一個用於英特爾x86相容容電腦的虛擬機器套裝,其允許使用者同時建立和執行多個x86虛擬機器。每個虛擬機器例項可以執行其自己的客戶機作業系統,如(但不限於)Windows、Linux、BSD變生版本。用簡單術語來描述就是,VMware工作站允許一臺真實的電腦在一個作業系統中同時開啟並執行數個作業系統。其它VMware產品幫助在多個宿主電腦之間管理或移植VMware虛擬機器。(via 維基百科)

 
二:Oracle VirtualBox是由德國InnoTek軟體公司出品的虛擬機器軟體,現在則由甲骨文公司進行開發,是甲骨文公司xVM虛擬化平臺技術的一部份。它提供使用者在32位或64位的Windows、Solaris及Linux 作業系統上虛擬其它x86的作業系統。使用者可以在VirtualBox上安裝並且執行Solaris、Windows、DOS、Linux、OS/2 Warp、OpenBSD及FreeBSD等系統作為客戶端作業系統。(via 維基百科)

 
三:Hyper-V採用微核心的架構,兼顧了安全性和效能的要求。Hyper-V底層的Hypervisor執行在最高的特權級別下,

微軟將其稱為ring -1(而Intel則將其稱為root mode),而虛擬機器的OS核心和驅動執行在ring 0,應用程式執行在ring 3下,這種架構就不需要採用複雜的BT(二進位制特權指令翻譯)技術,可以進一步提高安全性。和很多朋友的想法不同,Hyper-V可以很好地支援Linux,我們可以安裝支援Xen的Linux核心,這樣Linux就可以知道自己執行在 Hyper-V之上,還可以安裝專門為Linux設計的Integrated Components,裡面包含磁碟和網路介面卡的VMbus驅動,這樣Linux虛機也能獲得高效能。下圖所示的就是Novell SUSE Linux 10 SP1,其中的
網絡卡驅動,其匯流排型別就是VMbus。
這對於採用Linux系統的企業來說,是一個福音,這樣我們就可以把所有的伺服器,包括Windows和Linux,全部統一到最新的Windows Server 2008平臺下,可以充分利用Windows Server 2008帶來的最新高階特性,而且還可以保留原來的Linux關鍵應用不會受到影響。

Win7不支援hyper-v虛擬機器,win8以上才可以安裝,而且要考慮windows的版本,家庭版是不行的。

 


Docker,或者準確一點說,容器技術,在近幾年裡幾乎成為了應用分發和叢集部署的預設技術了。背景部分,如果感興趣,請參考閒談叢集管理模式一文。Docker 生態的成熟還有賴於其周邊工具和實踐模式的興起。比如,曾經雨後春筍般出現的編排技術,以及基於容器技術的 DevOps 實踐大規模地開展。

那麼這麼好的技術,在 Windows 上能用嗎?在各種場合,都有人與我討論這個的話題。每次聽到這樣的疑問,我也是很無奈的。畢竟,只要稍微搜尋一下,就不難回答:是可以的。不過,深入想一下,人們有這樣的疑問也是有道理的:畢竟 Docker 是起源於 Linux 上的技術。

Docker 是基於 Linux 內建的 Namespace 和 CGroup 等系統內隔離機制而抽象出來的一種輕虛擬化技術。與虛擬機器相比,它以一種輕量級的方式實現了執行空間的隔離。如果物理機是一幢住宅樓,虛擬機器就是大樓中的一個個套間,而容器技術就是套間裡的一個個隔斷。不難理解,Docker 作為一種隔斷,它並不能基於一種核心(Linux)提供另一種核心(Windows)的虛擬化執行環境。所以,基於 Linux 的 Docker 是不支援執行 Windows 應用的。

早在 Docker 之前,Linux 就已經提供了今天的 Docker 所使用的那些基礎技術。當年 Docker 彷彿一夜之間突然火爆全球的背後,技術上的積累並不是瞬間完成的。這一切在 Windows 上顯得有些滯後。在 Docker 已經眾所周知的時候,Windows 系統卻根本沒有類似的機制,更別提 Windows 獨有的工具鏈和實踐方法了。所以,我們看到,早期 Windows 與 Docker 的交集只是為其提供應用開發環境。

boot2docker 與 Docker for Windows

可以在 Windows 開發面向 Docker 部署的應用程式——Windows 的桌面體驗比 Linux 好太多,所以很早就出現了在異構作業系統上以虛擬機器的形式執行 Docker 的專案出現,也就是 boot2docker。它既支援 Windows,也支援 macOS。

後來,Docker 公司開始推出自己的 Docker for Windows 工具包,它旨在為開發人員在 Windows 上開發面向 Docker 的應用程式提供完整的工具鏈,其中包括執行環境、客戶端,Docker Swarm 編排工具和其他工具。Docker for Windows 中負責執行環境配置的工具是 Docker Machine。與 boot2docker 類似,Docker Machine 也會在 Windows 上建立一個 Linux 虛擬機器,用於執行 Docker 引擎。也就是說,這個環境也只支援 Linux 的應用程式格式的,並不支援 Windows 應用程式的執行。

Windows 容器技術

正當 Linux 世界的容器技術藉著 Docker 的東風颳遍世界的時候,Windows 系統也發現了容器粒度的重要性。 微軟與 Docker 在 2014 年宣佈了合作,以期將容器技術帶到 Windows Server 作業系統,併為傳統的 Windows 應用程式的容器化改造提供更直接的支援。不久之後,微軟在 Ignite 2015 上宣佈將推出為容器優化的 Windows Nano Server;第一次 Windows 容器真正與與開發者見面是在 Windows 10 的年度更新(2016.8)上,它正式提供 Windows 容器的開發環境。在 2017 年 10 月釋出的 Windows Server 1709 版本包含了 Windows 容器,意味著這項技術可以用於生產環境了。Windows 容器是真正能夠執行 Windows 應用程式的容器技術,包括依賴 IIS、登錄檔等大量 Windows 特性的應用程式都可以在 Windows 容器中執行。

雖然 Windows 對容器的支援有些姍姍來遲,但社群對 Windows 容器的關注和運用卻是異常活躍。這主要得益於容器技術本身生態的成熟,一來人們對這項技術已經有了充分的認知,同時周邊工具和實踐都已經日趨完善。另一方面,在與 Docker 公司一同打造這項技術的過程中,也注意了與已有技術的相容性。人們發現,在電腦上啟用 Windows Container 功能之後,接下來的操作步驟仍然是基於 Docker 客戶端完成的,命令列引數與 Linux 上的 Docker 也沒有區別。

幾乎與 Windows 容器技術本身日趨成熟過程的同時,周邊工具對 Windows 容器的支援也在同步完善。Docker for Windows 在新的版本中添加了一個貼心的選單,可以一鍵切換 Linux 容器和 Windows 容器;Kubernetes 從 1.5 版本開始增加對 Windows 容器的支援;雲環境方面,包括 Azure 和 AWS 在內的眾多雲環境都第一時間提供了 Windows 容器的支援……

Windows 容器架構

Windows 是如何既提供自有容器技術,又提供與 Docker 相容的操作介面的呢? 下面的左圖是 Linux 容器的架構,右側則是 Windows 容器的。可以發現兩者結構很類似。與 Linux 類似,Windows 也新新抽象出來了 CGroup 和 Namespace 的概念,並提供出一個新的抽象層次 Compute Service,即宿主機運算服務(Host Compute Service,hcs)。相較於底層可能經常重構的實現細節,hcs 旨在為外部(比如 Docker 引擎)提供較穩定的操作介面。hcs 的操作介面目前有 Go 語言版本,以及 C# 語言版本,前者目前在 Docker 客戶端中用來操作 Windows 容器。

容器映象方面,微軟自己提供了 Server Core 和 Nano Server 兩種伺服器版本。Server Core 可以理解為 Windows Server 去掉了 GUI 的部分,因此功能更完整(比如包括檔案伺服器、DNS 伺服器等功能),同時映象大小也更大(2GB~5GB);而 Nono Server 則是專為容器優化的迷你型系統,只包含有核心的 Windows 伺服器功能,映象大小為(130MB~400MB)。基於基礎映象來構建自己映象的方法與 Linux 映象是一樣的,所以 DockerFile 檔案的格式和語法並沒有不同。 授權方面,只要使用者已經取得宿主機的授權,微軟並不會單獨向用戶收取容器映象的授權費

小結

容器技術本身以及圍繞它的一系列工具和實踐讓應用程式的打包和釋出變得標準化,很大程度上可以消除應用程式對特定環境的依賴,進而為高效的叢集化部署和運維提供有力保障。作為容器技術的代表,Docker 可以以兩種形式執行在 Windows 上:以 Hyper-V 虛擬機器的形式執行 Linux 格式的容器,或者執行原生的 Windows 容器。其中前者執行 Linux 格式的應用程式,後者能執行 Windows 應用程式。如果稍微用一點技巧,還可以讓這兩者同時執行在 Windows 電腦上

Windows 10 和 Windows Server 都提供了對 Windows 容器的支援,各種容器化工具對 Windows 容器的支援也在日趨完善當中。基於 Windows 開發新的應用時一方面可以優先考慮跨平臺容器化部署的能力,另一方面也可以與存量應用程式一樣考慮藉助 Windows 容器技術實現容器化、雲原生的特性。

 

docker執行是需要linux核心的,為了能在非linux系統使用docker,官方早期提供的Toolbox方案就是使用虛擬機器啟動一個linux,然後在這個虛擬機器中執行docker,免費的虛擬機器當時使用最多的就是virtualbox
現在有原生版本的docker了,在windows上是使用的windows10內建的hyper-v虛擬機器,所以不在需要安裝virtualbox,但是對系統的要求也提高了,因為hyper-v的虛擬機器只有部分版本的windows10才有內建,比如家庭版的windows10就沒有hyper-v元件,不能執行原生版本的docker,還是隻能通過toolbox

 

以下都是我的我分析:win7沒有Hyper-V,win8以上才有Hyper-V,所以win7只能使用dockerToolbox,是基於VirtualBox虛擬機器軟體來構建一個叫default的linux系統,在這之上來使用docker的,並且應用是Linux的。

而win8也只能使用dockerToolbox,因為docker for windows是在window10和windowsServer2016以後才出來的,所以win8也是基於linux系統來使用docker的,其上的應用也是linux的應用。但是可以不使用VirtualBox虛擬機器,而使用Hyper-V來構建linux系統。我沒有在win8進行過測試。所以也是猜測