若是你須要大規模的容器編排,想必Kubernetes毋庸置疑是你的首要選擇,這一由谷歌推出的開源容器編排系統近年來發展飛速,大受業界及廣大用戶好評。html
儘管如此,對於大多數用戶而言,Kubernetes存在着學習曲線陡峭、難以設置和配置的問題,致使終端用戶須要承擔繁重的管理工做。基於此,最佳的解決辦法並不是單槍匹馬學習並直接上手Kubernetes,而是尋找一個完善的容器技術解決方案,這種方案一般將Kubernetes納爲其支持和維護的組件之一,使用起來一般更直觀和簡潔,如此一來便極大程度下降了Kubernetes的上手門檻。docker
在本文中,我列出了10個業界最流行的Kubernetes相關產品,包括了Kubernetes發行版、容器工具、不一樣的供應商提供的Linux內核等等。ubuntu
本文的列表不包括Amazon EKS或者Google Kubernetes Engine(GKE)這樣的雲服務,僅僅列出了能夠在本地運行或做爲雲託管的軟件發行版。安全
目 錄服務器
十大Kubernetes發行版架構
Rancher 2.0負載均衡
https://rancher.com/kubernetes/運維
嚴格來講,Rancher 2.0並非一個單純的Kubernetes發行版,而是一個開源的Kubernetes管理平臺。Rancher 2.0 爲企業用戶提供Kubernetes-as-a-Service (Kubernetes即服務),且可以實現多Kubernetes集羣的統一納管,不論這些Kubernetes集羣在何處、以何種方式部署。這解決了生產環境中企業用戶可能面臨的基礎設施不一樣的困境。Rancher 2.0能統一納管來自Google(GKE)、Amazon(EKS)和Azure(AKS)等公有云上託管的Kubernetes服務的平臺。分佈式
Rancher Labs公司在2019年發佈了提供輕量級的Kubernetes發行版,K3s。這款產品專爲在資源有限的環境中運行Kubernetes的研發和運維人員設計。其每一個服務器實例僅需512MB RAM以及200MB的磁盤空間。它刪除了舊的、非必須的代碼,整合正在運行的打包進程,使用containerd代替Docker做爲運行時的容器引擎,並在除etcd以外引入了SQLite 做爲可選的數據存儲,經過這些變化極大地減小了運行所需的空間和資源。工具
CoreOS Tectonic/Red Hat CoreOS
CoreOS提供以容器爲中心的Linux發行版,它兼容Docker,但又有固定的鏡像格式、它本身的runtime、以及一個「企業級Kubernetes發行版」。上述這些共同構成了CoreOS Tectonic堆棧的基礎。
CoreOS操做系統Container Linux是業界的一大流行產品,它的亮點之一在於它就像一組容器化組件,用戶無需關閉正在運行的應用程序,便可將操做系統的自動更新整合到生產環境中。CoreOS還能夠對Kubernetes進行「一鍵式」更新。此外,CoreOS Tectonic能夠在Amazon Web Services、Microsoft Azure以及裸機上運行。
Red Hat收購了CoreOS以後,計劃將其集成到Red Hat OpenShift中。Container Linux將被從新命名爲Red Hat CoreOS。此舉預計將在2020年以前完成,在此以前Container Linux將繼續獲得支持。根據Red Hat的說法,過渡後將提供「幾乎全部」CoreOS Tectonic的功能。
Canonical Distribution of Kubernetes(CDK)
Canonical,Ubuntu Linux的製造商,也擁有本身的Kubernetes發行版,即Canonical Distribution of Kubernetes(CDK)。該發行版的一大賣點是它是一款普遍受到支持、易於理解且廣泛部署的Ubuntu Linux發行版。Canonical聲稱其堆棧既能夠在任何雲上運行,也能夠在本地部署,並支持CPU和GPU驅動的工做負載。付費客戶還能享受Canonical的工程師遠程管理他們的Kubernetes集羣的服務。
Canonical的Kubernetes發行版也有輕量級版本的,叫Microk8s。開發人員以及Kubernetes新手能夠在筆記本或者臺式機上安裝Microk8s,將其用於測試、實驗,甚至在那些硬件配置低的生產環境中使用。
此外,Canonical和Rancher Labs共同開發了一個產品叫作「雲原平生臺(Cloud Native Platform,簡稱CNP)」,它將Canonical的Kubernetes發行版和Rancher的容器管理平臺相匹配。如此,就可使用Kubernetes管理運行在每一個集羣上的容器而且用Rancher管理多Kubernetes集羣。目前,CNP已經在Rancher 2.x的版本中可使用。
Docker 社區版 / Docker 企業版
https://www.docker.com/products/kubernetes
對於不少人來講,Docker僅僅是容器。但實際上,2014年以後Docker也有它本身的集羣和編排系統,Docker Swarm,而這一系統曾是Kubernetes的競爭對手。直到2017年10月,Docker宣佈將在其未經修改的、永久標準的狀態中添加Kubernetes做爲標準打包方式,這一調整涵蓋了Docker Community Edition和Docker Enterprise 2.0及之後的版本。
Docker Enterprise 3.0添加了Docker Kubernetes服務,這一Kubernetes集成能夠保持開發人員桌面和生產部署環境中Kubernetes版本一致。
簡而言之,Docker公司已經意識到Kubernetes比Swarm更適合管理龐大、複雜的容器環境。然而,Docker依然包括其原始的集羣系統「swarm 模式」,它更適用於那些不太複雜的工做,例如部署一個無需擴展太多的本地的、受保護的應用程序或者維護不須要修改的現有swarm模式集羣。
Heptio Kubernetes 訂閱版
https://heptio.cloud.vmware.com/
Kubernetes的兩位創始人Craig McLuckie和Joe Beda,創辦了Heptio,主要圍繞Kubernetes提供服務和產品。他們第一個主打產品是一個付費的Kubernetes部署服務, Heptio Kubernetes Subscription(HKS)。Heptio提供全天候的技術支持,收費是每個月2000美圓及以上。
Heptio的主要優點在於它是企業級的Kubernetes,又不懼怕廠商鎖定。它能夠在公有云或者私有硬件上運行部署。全部Heptio提供的用於管理Kubernetes配置的工具都是開源的,而且修復程序能夠直接交付到支持的集羣。
2018年VMware收購了Heptio,不過這次收購目前暫未影響Heptio的產品計劃。
Kontena Pharos
https://www.kontena.io/pharos/
Kontena Pharos的定位是「Kubernetes that just works」,它與Red Hat的Linux產品擁有大體相同的「劇本」。底層架構是通過CNCF認證的Kubernetes發行版,能夠在Apache 2許可下使用(和Fedora或CentOS同樣)。付費客戶能夠得到專業級功能、技術諮詢、支持服務和特定固訂價格的產品,好比遷移到雲原生基礎設施。
核心Pharos發行版默認配置了自動安全更新和多個容器運行時等基本功能。付費的版本則添加了企業工具,好比Kontena Lens面板、Kontena Storage分佈式存儲系統、備份、負載均衡以及在內網隔離環境中部署集羣。
專業版有30天的試用期,訂閱的費用爲每個月近3000美圓起。而開源的版本則沒有時間的限制也不須要許可費用。
Pivotal 容器服務 (PKS)
https://pivotal.io/cn/platform/pivotal-container-service
Pivotal,以其在Cloud Foundry上的表現而爲人熟知,它擁有企業級Kubernetes服務,即Pivotal Container Service(PKS)。PKS吸收了許多其餘Pivotal項目的靈感,例如,它使用曾經用於Pivotal的Cloud Foundry的Kubo項目來啓動和管理Kubernetes集羣。
PKS一個最突出的特性是與VMware虛擬機堆棧緊密集成,事實上,PKS是VMware-Pivotal的聯合項目。運行在PKS上的容器能夠訪問在vSphere上運行的虛擬機可用的服務,譬如VMware VSAN中的持久存儲。此外,PKS能夠經過用於在公有云和私有云環境中管理VMware基礎設施的VMware Cloud Foundation進行管理。
簡而言之,任何使用VMware而且對Kubernetes愈來愈感興趣的企業可能但願研究PKS以充分利用他們現有的VMware設置。
Red Hat OpenShift
https://www.redhat.com/en/technologies/cloud-computing/openshift
OpenShift是紅帽的PaaS產品,最初使用與Heroku buildpack相似的「盒式磁帶」打包應用程序,而後將其部署在稱爲「齒輪」的容器中。而後Docker出現了,OpenShift通過了從新設計,使用新的容器鏡像和運行時標準。不可避免地,Red Hat採用了Kubernetes做爲OpenShift中的編排技術。
OpenShift還爲PaaS中的全部組件提供抽象化和自動化。這種抽象和自動化擴展到Kubernetes,會帶來至關大的管理負擔,所以OpenShift能夠用來緩解這一過程,做爲部署PaaS的更爲重要的一部分。
如上文所提到的,CoreOS Tectonic正在合併到Red Hat OpenShift中,雖然技術合併預計要到2020年才能完成。
SUSE 容器服務平臺
https://www.suse.com/products/caas-platform/
因Linux 發行版而在歐洲廣爲人知的SUSE也擁有 SUSE CaaS平臺。概念上,SUSE CaaS平臺讓人想起CoreOS Tectonic,它結合了運行容器的裸機「微型」操做系統、Kubernetes、內置的鏡像倉庫和集羣配置工具。
SUSE CaaS Platform3於2018年發佈,在這一版本中添加了多主機功能以使集羣更能適應主節點崩潰和內核調整功能,以便對包含的Linux內核進行自定義調整。
SUSE CaaS平臺能夠在公有云和本地裸機上運行,但需注意SUSE目前沒法支持任何與底層雲基礎架構的集成。這意味着SUSE CaaS平臺不是爲了補充Amazon EKS或Google Kubernetes Engine而設計的,而是爲了規避他們,讓您能夠跨多個雲和數據中心運行容器。
Telekube
https://gravitational.com/gravity/
Teleport SSH服務器的所屬公司Gravitational開發了Gravity,這是一種在本地或遠程集羣上運行的「強化生產」Kubernetes發行版。Gravity的定位是私有SaaS平臺的解決方案或在多個區域及託管提供商中運行Kubernetes-as-a-service。
Gravity上的應用程序要想在Kubernetes上的容器中運行,必須作一些前提準備。它們必須首先被打包成「Bundles」,這些「Bundles」以後會被髮布到Kubernetes集羣進行分發。這些「綁定」屬於額外工做,除此以外咱們常見的部署容器應用程序所需的準備工做也仍然須要作,不過Bundle清單也是Gravity惟一須要的額外工做了。
Gravity包含拍攝整個Kubernetes集羣的快照的功能,其中包括全部的應用程序和配置,而且用戶能夠部署快照到任意其餘Kubernetes環境中。
結 語
Kubernetes和容器正在改變應用程序的建立、部署以及管理的方式。而本文列出的這些Kubernetes發行版,正在引領着這場變革。
原文連接: