什麼是docker

docker簡介

    Docker 提供了一個可以運行你的應用程序的封套(envelope),或者說容器。它原本是 dotCloud 啓動的一個業餘項目,並在前些時候開源了。它吸引了大量的關注和討論,導致 dotCloud 把它重命名到 Docker Inc。它最初是用 Go 語言編寫的,它就相當於是加在 LXC(LinuX Containers,linux 容器)上的管道,允許開發者在更高層次的概念上工作。

    Docker 擴展了 Linux 容器(Linux Containers),或着說 LXC,通過一個高層次的 API 爲進程單獨提供了一個輕量級的虛擬環境。Docker 利用了 LXC, cgroups 和 Linux 自己的內核。和傳統的虛擬機不同的是,一個 Docker 容器並不包含一個單獨的操作系統,而是基於已有的基礎設施中操作系統提供的功能來運行的。

    Docker類似虛擬機的概念,但是與虛擬化技術的不同點在於下面幾點:

    1.虛擬化技術依賴物理CPU和內存,是硬件級別的;而docker構建在操作系統上,利用操作系統的containerization技術,所以docker甚至可以在虛擬機上運行。

    2.虛擬化系統一般都是指操作系統鏡像,比較複雜,稱爲“系統”;而docker開源而且輕量,稱爲“容器”,單個容器適合部署少量應用,比如部署一個redis、一個memcached。

    3.傳統的虛擬化技術使用快照來保存狀態;而docker在保存狀態上不僅更爲輕便和低成本,而且引入了類似源代碼管理機制,將容器的快照歷史版本一一記錄,切換成本很低。

    4.傳統的虛擬化技術在構建系統的時候較爲複雜,需要大量的人力;而docker可以通過Dockfile來構建整個容器,重啓和構建速度很快。更重要的是Dockfile可以手動編寫,這樣應用程序開發人員可以通過發佈Dockfile來指導系統環境和依賴,這樣對於持續交付十分有利。

    5.Dockerfile可以基於已經構建好的容器鏡像,創建新容器。Dockerfile可以通過社區分享和下載,有利於該技術的推廣。

    Docker 會像一個可移植的容器引擎那樣工作。它把應用程序及所有程序的依賴環境打包到一個虛擬容器中,這個虛擬容器可以運行在任何一種 Linux 服務器上。這大大地提高了程序運行的靈活性和可移植性,無論需不需要許可、是在公共雲還是私密雲、是不是裸機環境等等。

    Docker也是一個雲計算平臺,它利用Linux的LXC、AUFU、Go語言、cgroup實現了資源的獨立,可以很輕鬆的實現文件、資源、網絡等隔離,其最終的目標是實現類似PaaS平臺的應用隔離。

    Docker 由下面這些組成:

    1. Docker 服務器守護程序(server daemon),用於管理所有的容器。

    2. Docker 命令行客戶端,用於控制服務器守護程序。

    3. Docker 鏡像:查找和瀏覽 docker 容器鏡像。

docker特性

    文件系統隔離:每個進程容器運行在完全獨立的根文件系統裏。

    資源隔離:可以使用cgroup爲每個進程容器分配不同的系統資源,例如CPU和內存。

    網絡隔離:每個進程容器運行在自己的網絡命名空間裏,擁有自己的虛擬接口和IP地址。

    寫時複製:採用寫時複製方式創建根文件系統,這讓部署變得極其快捷,並且節省內存和硬盤空間。

    日誌記錄:Docker將會收集和記錄每個進程容器的標準流(stdout/stderr/stdin),用於實時檢索或批量檢索。

    變更管理:容器文件系統的變更可以提交到新的映像中,並可重複使用以創建更多的容器。無需使用模板或手動配置。

    交互式Shell:Docker可以分配一個虛擬終端並關聯到任何容器的標準輸入上,例如運行一個一次性交互shell。

兩個基礎概念images與container

    Container和Image 在Docker的世界裏,Image是指一個只讀的層(Layer),這裏的層是AUFS裏的概念

    Docker使用了一種叫AUFS的文件系統,這種文件系統可以讓你一層一層地疊加修改你的文件,最底下的文件系統是隻讀的,如果需要修改文件,AUFS會增加一個可寫的層(Layer),這樣有很多好處,例如不同的Container可以共享底層的只讀文件系統(同一個Kernel),使得你可以跑N多個Container而不至於你的硬盤被擠爆了!這個只讀的層就是Image!而如你所看到的,一個可寫的層就是Container。

    那Image和Container的區別是什麼?很簡單,他們的區別僅僅是一個是隻讀的層,一個是可寫的層,你可以使用docker commit 命令,將你的Container變成一個Image,也就是提交你所運行的Container的修改內容,變成一個新的只讀的Image,這非常類似於git commit命令。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章