Docker和容器的區別?容器技術早已存在,Docker 是屬于容器服務的一種,是一個開源的應用容器引擎。
傳統的容器技術沒有成為主流的原因,是因為其未能提供標準化的應用運行時環境,而以Docker為代表的新一代容器技術,從一開始就以提供標準化的運行時環境為目標,真正做到“build once, run anyWhere”(一次建立,到處運行)。
docker容器可以將同一個構建版本用于開發、測試、預發布、生產等任何環境,并且做到了與底層操作系統的解耦。在此基礎上,還進一步發展出了CaaS(容器即服務)技術。
將 Docker 比喻為代碼方面的集裝箱運輸系統,確實非常形象恰當。
Docker將任何類型的應用和它的依賴打包成為一個標準的、輕量級的、便攜的、獨立的集裝箱,讓各類應用都支持一套標準的運作模式,只要安裝了Docker程序的服務器都可以運行。
開發者開發和測試完成的Docker容器,可以無差別的運行在測試環境、生產環境,無論服務器是物理機、虛擬機,或者是以上各種類型服務器的組合。應用開發過程只需執行一次,即可保證應用在任何環境上運行的一致性。對于運維人員,則只需要配置一次不同環境的服務器,即可運行任何Docker容器。
當容器和服務器的數量達到一定規模的時候,就會碰到管理的問題,即如何有效管理大量的服務器和容器,保證應用的穩定運行、方便升級和故障的快速解決。
容器編排工具提供圖形化界面或者命令行來管理容器和服務器集群,提供容器配置、任務發布、服務發現、負載均衡、系統監控和故障恢復、聲明式系統配置以及有關容器部署和性能的規則和約束定義機制等。
google開發的Kubernetes從眾多編排工具中脫穎而出。相比Kubernetes,Docker原生編排工具Swarm在集群搭建和使用上要相對簡單一些,學習和部署成本相對低一些。較新版本的Docker已經集成了Swarm。Swarm支持跨多個主機進行編排,管理較小規模的容器集群也綽綽有余,對于初學者也可以很快的部署和運行。