在 Windows 上可以用 Docker 嗎?

來源:互聯網
上載者:User

標籤:核心   www.   war   微軟   win   區別   tar   namespace   案頭   

陳計節
個人部落格:https://blog.jijiechen.com/post/docker-on-windows/

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

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

Docker 是基於 Linux 內建的 Namespace 和 CGroup 等系統內隔離機制而抽象出來的一種輕虛擬化技術。與虛擬機器相比,它以一種輕量級的方式實現了Runspace的隔離。如果物理機是一幢住宅樓,虛擬機器就是大樓中的一個個套間,而容器技術就是套間裡的一個個隔斷。不難理解,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 容器技術實現容器化、雲原生的特性。

在 Windows 上可以用 Docker 嗎?

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.