Docker是什麼?
簡單得來說,Docker是一個由GO語言寫的程式運行的「容器」(Linux containers, LXCs); 目前雲端服務的基石是作業系統層級的隔離,在同一台實體伺服器上虛擬出多個主機。 Docker則實現了一種應用程式層級的隔離; 它改變我們基本的開發、操作單元,由直接操作虛擬主機(VM),轉換到操作程序運行的「容器」上來。
Docker是為開發者和系統管理員設計的,用來發布和運行分散式應用程式的一個開放性平台。由兩部分組成:
Docker Engine: 一個便攜式、輕量級的運作環境和套件管理器。 (註* 單OS vs 單線程,是不是跟NodeJS特別像?)
Docker Hub: 為建立自動化工作流程和分享應用程式所建立的雲端服務組成。 (註* 雲端映像/套件管理vs npm套件管理,是跟npm特別像?)
從2013年3月20日,第一個版本的Docker正式發佈到2014年6月 Docker 1.0 正式發布,經歷了15個月。 雖然發展歷程很短,但Docker正在有越來越流行的趨勢。
其實Container技術並非Docker的創新,HeroKu, NodeJitsu 等雲端服務商都採用了類似這種輕量級的虛擬化技術,但Docker是第一個將這種Container技術大規模開源並被社群廣泛接受的。
好的部分
Docker相對於VM虛擬機的優勢十分明顯,那就是輕量和高效能和便捷性, 以下部分: KVM and Docker LXC Benchmarking with OpenStack<〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜〜)效能可以獲得極大提升(經典的案例是提升97%)
管理操作(啟動,停止,開始,重啟等等) 都是以秒或毫秒為單位的。
敏捷
像虛擬機一樣敏捷,而且會更便宜,在bare metal(裸機)上佈署像點個按鈕一樣簡單。
靈活
將應用和系統“容器化”,不添加額外的操作系統,
輕量
你會擁有足夠的“操作系統”,僅需添加小鏡”,僅需添加小鏡即可。在一台伺服器上可以佈署100~1000個Containers容器。
便宜
開源的,免費的,低成本的。由現代Linux核心支援並驅動。註* 輕量的Container必定可以在一個實體機上開啟更多“容器”,注定比VMs便宜。
生態系統
正在越來越受歡迎,只需要看一看Google的趨勢就知道了, docker or LXC.
還有不計其數的社區和第三方應用。
雲端支援
不計其數的雲端服務提供建立和管理Linux容器框架。
有關Docker效能方面的優勢,還可參考此IBM工程師對效能提升的評測,從各方面比VMs(OS系統層級虛擬化)都有非常大的提升。
Performance Characteristics of VMs vs Docker Containers by Boden Russel (IBM)
Performance characteristics of traditional v ms vs docker containers〜㟜〜㟜〜,跳㟜〜,<〜〜㟜〜㟜,㟎㟜〜㟜,都會爭論? , 同樣Docker也有一些。
能否徹底隔離
在超複雜的業務系統中,單OS到底能不能實現徹底隔離,一個程式的崩潰/記憶體溢出/高CPU佔用到底會不會影響到其他容器或整個系統?許多人對Docker能否在實際的多主機的生產環境中支援關鍵任務系統還有懷疑。 註* 就像有人質疑Node.JS單線程快而不穩,無法在複雜場景中應用一樣。
不過可喜的是,目前Linux核心已經針對Container做了很多改進,以支援更好的隔離。
GO語言還沒有完全成熟
Docker由Go語言開發,但GO語言對大多數開發者來說比較陌生,而且還在不斷改進,距離成熟還有一段時間。此半git、半包管理的方式讓一些人產生不適。
被私有公司控制
Docker是一家叫Dotcloud的私有公司設計的,公司都是以營利為目的,比如你沒有辦法使用源代碼編制Docker項目,只能使用黑匣子編出的Docker進制包,未來可能不是完全免費的。 目前Docker已經推出以公司為導向的企業級服務(諮詢、支援和培訓)。