摘要:由谷歌開發(fā),允許你在許多不同的主機上管理容器化應用程序。它已經(jīng)被完全開源,谷歌在年首次宣布開發(fā)它,第一版在夏天的時候發(fā)布。除了最近幾年的收獲,本身也是基于谷歌內(nèi)部十多年使用容器技術的經(jīng)驗。
基于云的基礎設施,容器,微服務和新編程平臺在世界范圍占據(jù)了一大塊媒體領域,橫掃IT界。Docker、容器的使用在這幾個月內(nèi)呈爆炸式增長,已經(jīng)提交了20億的鏡像“pulls”;鏡像數(shù)在2015年11月就已達12億。從大型國際公司到小型創(chuàng)業(yè)公司,容器技術的使用都有明顯增長。
集群管理工具總覽很明顯,容器在創(chuàng)建和交付應用程序的過程中有著新發(fā)展。然而,大范圍控制容器部署也會有一些并發(fā)癥。容器肯定是跟資源相匹配的。故障肯定是越快解決越好。這些挑戰(zhàn)會導致集群管理和編排的并發(fā)需求。
集群管理工具是一個通過圖形界面或者通過命令行來幫助你管理一組集群的軟件程序。有了這個工具,你就可以監(jiān)控集群里的節(jié)點,配置services,管理整個集群服務器。集群管理可以從像發(fā)送工作到集群的低投入活動,到像負載均衡和可得性的高介入工作。在這篇文章中,我們來看一下目前比較受歡迎的集群管理工具,并討論一下他們的優(yōu)點和面臨的挑戰(zhàn)。
Docker Swarm讓你聚集一些Docker引擎到一個虛擬引擎。在一個分布式應用程序環(huán)境中,計算元素必須也是可以被分布的。Swarm允許你在本地聚集Docker引擎。有了單個引擎,應用程序可以被擴展得更快,更有效率。Swarm能夠擴容到50000個容器,1000個節(jié)點,同時當容器添加到集群的時候一點都不影響性能。
再加上,Swarm的角色相當于Docker API。任意可以操作Docker Daemon的工具都可以運用Docker Swarm的力量在很多主機上進行擴容。這些包括了像Flynn,Compose,Jenkins和Drone之類不同的主機。
Swarm也可以在后端運行Mesos或者Kubernetes的時候,被用來作為前端Docker客戶端。Swarm在它的核心內(nèi)部是一個簡單的系統(tǒng):每個主機運行一個Swarm代理與管理員。管理員處理容器的操作和調(diào)度。你可以在高可用狀態(tài)下運行,它使用的是Consul,ZooKeeper或者etcd來發(fā)送容錯events到后端系統(tǒng)。
Docker Swarm的一個優(yōu)點就是,它是一個本地解決辦法——你可以用Docker命令來實施Docker網(wǎng)絡,插件和數(shù)據(jù)卷。Swarm管理員為leader選舉創(chuàng)建一些master和特定的規(guī)定。這些條例實施在初級master故障的event里。Swarm調(diào)度器以各種各樣的過濾包為特色,也包括緊密性和節(jié)點標簽。過濾包能夠附加容器到底層節(jié)點,資源得到更好的利用,性能得到提升。
Core OS被創(chuàng)建來允許彈性擴容,允許管理計算能力。與其通過apt或者yum安裝包,Core OS覺得倒不如利用Linux容器來處理更高抽象水平的service,提供好處給虛擬機,但是重點是在應用程序上而不是在完成虛擬化主機上。
Fleet能夠在它分享個體初始系統(tǒng)的場景中將Core OS集群虛擬化。有了Fleet,每個機器都有一個代理和一個引擎。雖然單個引擎在集群中的任意節(jié)點都是活躍的,但是整個引擎社區(qū)一直都是活躍的。Fleet也可以處理套借口激活——容器可以被用來處理在特殊接口的連接。這就允許系統(tǒng)在需要的時候創(chuàng)建進程而不是等待需求的時候再去創(chuàng)建。
你們的開發(fā)運維人員將他們的時間重點花在管理作為service創(chuàng)建基礎的容器上,同時不需要擔心可能出現(xiàn)在單個機器上的潛在問題。Fleet確保在集群中的容器在操作狀態(tài)。在發(fā)生機器故障的時候,容器會自動轉(zhuǎn)移到健康的機器上。
Kubernetes由谷歌開發(fā),允許你在許多不同的主機上管理容器化應用程序。它提供工具讓你部署,彈性擴容和維護應用程序。Kubernetes的開發(fā)者致力于保持它一直處于可訪問、輕量級狀態(tài),并且易于使用。它可以在很多云環(huán)境中使用,包括私有云,公有云,多云端和混合云。Kubernetes可以在fly上進行自我修復,它以自動復制,自動再啟動,自動定位為特色。它可以被不斷擴展,它的特點是hookable,可插拔和模塊化。它已經(jīng)被完全開源,谷歌在2014年首次宣布開發(fā)它,第一版在2015夏天的時候發(fā)布。除了最近幾年的收獲,Kubernetes本身也是基于谷歌內(nèi)部十多年使用容器技術的經(jīng)驗。
Kubernetes使用容器組pod,并且在同時被調(diào)度和部署。調(diào)度的基礎配置是pods,因為相比于系統(tǒng),單個容器會被當成是基礎單元。大部分的pods最多有5個容器,這就組成了一個service。Pods會按照需求在現(xiàn)實生活中創(chuàng)建和刪除,或許修改。
Kubernetes是一系列寬松的、可以在很多不同的工作負載下操作的松散耦合原語。它很大程度上依賴于Kubernetes API的可擴展性。API在內(nèi)部使用,同樣的,在外部被容器和拓展版本運行在系統(tǒng)中。目前,已經(jīng)應用Kubernetes的項目和企業(yè)包括:Wikimedia Foundation從本土設置轉(zhuǎn)移到Kubernetes;eBay在OpenStack上運行Kuberenetes和容器;Viacom用Kubernetes創(chuàng)建了一個先進的容器化基礎設施。
Apache Mesos是一個集群管理工具,它著重于資源隔離,以及分布式網(wǎng)絡或者在框架上分享應用程序,它的構想和開發(fā)源于加州大學伯克利分校。
一個開源系統(tǒng),它會給管理員分享資源、提升集群利用率的功能。目前使用Apache Mesos的公司包括:Apple,Airbnb和Twitter。
Apache Mesos對于像CPU,Disk和RAM之類的計算元件來說是一個抽象層。它運行在每臺機器上,其中一臺機器被設計來作為master來運行其它機器。任意Linux程序都可以運行在Mesos上面。Mesos的一個優(yōu)點就是應對故障,它會提供額外的安全層。
Mesos被設計來處理成千上萬的主機,支持各種各樣主機上的工作負載。在一個Mesos配置上,你可能會發(fā)現(xiàn)Docker和Hadoop并排運行。幾年前,當系統(tǒng)支持Twitter的快速擴張的時候Mesos做到了可視化。
Mesos使用代理節(jié)點系統(tǒng)來運行任務。代理發(fā)送一張可得資源清單到master。在任意時刻,都會有成千上萬的代理節(jié)點在進行操作。同樣,master也會分布任務到代理上。
Kubernetes是一個全徑且全面的容器管理平臺,有動態(tài)調(diào)度、升級、自動伸縮和持續(xù)健康監(jiān)測的功能。相較而言,Docker Swarm只是從單個容器引擎提供一個集群系統(tǒng)的視角。
Mesos和Kubernetes比較相似,因為他們都是被開發(fā)來解決在集群化環(huán)境中運行應用程序的問題。但Mesos在運行集群方面不如Kubernetes,它重點放在它強大的調(diào)度功能和它被插在各種各樣的調(diào)度器的性能上。Mesos并不是為容器而生的,在容器流行之前就已經(jīng)被開發(fā)出來,它的一些地方被修改來支持容器。
Fleet利用etcd,一個和Core OS一起做出來被系統(tǒng)化的鍵值對,對于Linux來說是一個系統(tǒng)和service管理員。系統(tǒng)化是為單個容器設計,但是fleet延展它的性能到一個集群的機器。Fleet通過允許你運行service的一些實例,來幫助項目應對故障。它可以部署單個的容器到任意本地,運行容器在一個或者多個機器上,并且部署一個容器的多個實例。
從另一個方面來說,F(xiàn)leet并不適用于處理一些像服務注冊,在調(diào)度基礎上利用,服務發(fā)現(xiàn)或者容器間的交流這些在分布式微服務環(huán)境中發(fā)生的情況。Fleet在這四個工具中屬于比較低調(diào)的引擎,所以它最好處于一個像Kubernetes或者其它解決方案可以在上面操作的層次。
現(xiàn)今的企業(yè)需要能夠滿足他們需求不會出現(xiàn)故障的冗余系統(tǒng)。另外,大數(shù)據(jù)和數(shù)據(jù)挖掘需要很多資源來過濾海量信息。除非這些公司適應和修改他們的登錄信息系統(tǒng)的方式,不然他們面對更快、更靈活的競爭對手會很快失去陣地。在現(xiàn)在這個高速網(wǎng)絡規(guī)模的時代,修復單個機器不是一個有效的解決方法。分布式系統(tǒng)允許你快速調(diào)度出故障的機器到垃圾箱,并且重新分配資源到健康集群的節(jié)點上。這就是管理Docker和其它容器集群重要性。
原文鏈接
(如果需要轉(zhuǎn)載,請聯(lián)系我們哦,尊重知識產(chǎn)權人人有責:)
文章版權歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/32452.html
摘要:王磊此次演講的題目為容器新技術架構下的運維實踐,詳細為大家講解了在基于構建容器的過程中,如何以應用為中心,通過新的技術工具對服務節(jié)點集群平臺等多個方面進行管理運維,提高系統(tǒng)的自動化運維能力。 2018年11月16-17日,運維&容器技術盛會 CNUTCon 全球運維技術大會在上?!す獯髸怪行某晒εe辦。時速云聯(lián)合創(chuàng)始人兼 CTO 王磊受邀參加此次大會,并發(fā)表主題演講。王磊此次演講的題目...
摘要:首先啟動該命令。這項機制在實際生產(chǎn)當中無疑非常重要。那么下面我們回顧一下之前了解到的信息我們創(chuàng)建了一款小型動態(tài)微服務應用,完全由構成。在多數(shù)情況下,這能夠為應用后端服務建立起獨立的代理機制。 這次數(shù)人云與大家分享的文章里,主要介紹了Docker Swarm如何憑借革新對整體場景進一步加以簡化。事實上,如今我們已經(jīng)可以輕松且直觀地構建起一套Docker Swarm集群,快來一起體驗一下吧...
摘要:因此,另一種解決辦法像這樣的工具,則只是將和進行了結合,其功能尤其關注日志管理,比如格式檢查,日志語法分析,數(shù)據(jù)改進地址地理位置信息,元數(shù)據(jù)標簽等以及日志路由。 由Rancher社區(qū)維護的應用商店最近迎來了兩個明星項目——SPM 和 Logsene,來自Sematext的監(jiān)控與日志工具。如果你已經(jīng)熟悉Logstash,Kibana,Prometheus,Grafana這些監(jiān)控或日志解決...
摘要:在我的前文容器可視化監(jiān)控中心搭建之中我們就實踐過容器的可視化監(jiān)控,在那篇文章中我們是使用了技術棧來完成的。 showImg(https://segmentfault.com/img/remote/1460000015484084); 概述 性能監(jiān)控是容器服務必不可少的基礎設施,容器化應用運行于宿主機上,我們需要知道該容器的運行情況,包括 CPU使用率、內(nèi)存占用、網(wǎng)絡狀況以及磁盤空間等...
閱讀 2896·2021-11-24 09:39
閱讀 2461·2019-08-30 15:53
閱讀 3034·2019-08-30 13:47
閱讀 1308·2019-08-30 12:50
閱讀 1487·2019-08-29 16:31
閱讀 2648·2019-08-29 13:14
閱讀 1566·2019-08-29 10:55
閱讀 800·2019-08-26 13:32