云計算服務(wù)架構(gòu)與OpenStack

最近在看CloudMan的《每天5分鐘玩轉(zhuǎn) OpenStack》系列文章吐绵,受益很多,這篇為學(xué)習(xí)總結(jié)篇,感謝閱讀~

一淋硝、云計算服務(wù)架構(gòu)

云計算是IT技術(shù)不斷發(fā)展的產(chǎn)物。 要理解云計算宽菜,需要對IT系統(tǒng)架構(gòu)的發(fā)展過程有所認識谣膳,可以通過下圖來理解云計算:

image

IT系統(tǒng)架構(gòu)的發(fā)展到目前為止大致可以分為3個階段:

1、物理機架構(gòu)
這一階段铅乡,應(yīng)用部署和運行在物理機上继谚。 比如企業(yè)要上一個ERP系統(tǒng),如果規(guī)模不大阵幸,可以找3臺物理機花履,分別部署Web服務(wù)器芽世、應(yīng)用服務(wù)器和數(shù)據(jù)庫服務(wù)器。 如果規(guī)模大一點诡壁,各種服務(wù)器可以采用集群架構(gòu)济瓢,但每個集群成員也還是直接部署在物理機上。 我見過的客戶早期都是這種架構(gòu)妹卿,一套應(yīng)用一套服務(wù)器旺矾,通常系統(tǒng)的資源使用率都很低,達到20%的都是好的夺克。

2箕宙、虛擬化架構(gòu)
摩爾定律決定了物理服務(wù)器的計算能力越來越強,虛擬化技術(shù)的發(fā)展大大提高了物理服務(wù)器的資源使用率铺纽。 這個階段柬帕,物理機上運行若干虛擬機,應(yīng)用系統(tǒng)直接部署到虛擬機上狡门。 虛擬化的好處還體現(xiàn)在減少了需要管理的物理機數(shù)量陷寝,同時節(jié)省了維護成本。

3其馏、云計算架構(gòu)
虛擬化提高了單臺物理機的資源使用率凤跑,隨著虛擬化技術(shù)的應(yīng)用,IT環(huán)境中有越來越多的虛擬機尝偎,這時新的需求產(chǎn)生了: 如何對IT環(huán)境中的虛擬機進行統(tǒng)一和高效的管理饶火。 有需求就有供給,云計算登上了歷史舞臺致扯。

計算(CPU/內(nèi)存)肤寝、存儲和網(wǎng)絡(luò)是 IT 系統(tǒng)的三類資源。 通過云計算平臺抖僵,這三類資源變成了三個池子 當需要虛機的時候鲤看,只需要向平臺提供虛機的規(guī)格。 平臺會快速從三個資源池分配相應(yīng)的資源耍群,部署出這樣一個滿足規(guī)格的虛機义桂。 虛機的使用者不再需要關(guān)心虛機運行在哪里,存儲空間從哪里來蹈垢,IP是如何分配慷吊,這些云平臺都搞定了。

云平臺是一個面向服務(wù)的架構(gòu)曹抬,按照提供服務(wù)的不同分為 IaaS溉瓶、PaaS 和 SaaS。 如下圖所示:

image

三層架構(gòu)的說明如下:
IaaS(Infrastructure as a Service)
基礎(chǔ)設(shè)施即服務(wù),該層提供的服務(wù)是虛擬機堰酿。 IaaS 負責(zé)管理虛機的生命周期疾宏,包括創(chuàng)建、修改触创、備份坎藐、啟停、銷毀等哼绑。 使用者從云平臺得到的是一個已經(jīng)安裝好鏡像(操作系統(tǒng)+其他預(yù)裝軟件)的虛擬機岩馍。 使用者需要關(guān)心虛機的類型(OS)和配置(CPU、內(nèi)存凌那、磁盤)兼雄,并且自己負責(zé)部署上層的中間件和應(yīng)用吟逝。 IaaS 的使用者通常是數(shù)據(jù)中心的系統(tǒng)管理員帽蝶。 典型的 IaaS 例子有 AWS、Rackspace块攒、阿里云等励稳。

PaaS(Platform as a Service)
平臺即服務(wù),該層提供的服務(wù)是應(yīng)用的運行環(huán)境和一系列中間件服務(wù)(比如數(shù)據(jù)庫囱井、消息隊列等)驹尼。 使用者只需專注應(yīng)用的開發(fā),并將自己的應(yīng)用和數(shù)據(jù)部署到PaaS環(huán)境中庞呕。 PaaS負責(zé)保證這些服務(wù)的可用性和性能新翎。 PaaS的使用者通常是應(yīng)用的開發(fā)人員。 典型的 PaaS 有 Heroku住练、Google App Engine地啰、IBM BlueMix 等。

SaaS(Software as a Service)
軟件即服務(wù)讲逛,該層提供的是應(yīng)用服務(wù)亏吝。 使用者只需要登錄并使用應(yīng)用,無需關(guān)心應(yīng)用使用什么技術(shù)實現(xiàn)盏混,也不需要關(guān)系應(yīng)用部署在哪里蔚鸥。 SaaS的使用者通常是應(yīng)用的最終用戶。 典型的 SaaS 有 Google Gmail许赃、Salesforce 等止喷。

現(xiàn)在,基于Docker的CaaS容器云平臺架構(gòu)設(shè)計也逐漸流行起來混聊,還有最新的容器編排框架k8s(Kubernetes)弹谁,詳細介紹可以參考這篇文章:基于Docker的CaaS容器云平臺架構(gòu)設(shè)計

二、云計算與OpenStack

OpenStack is a cloud operating system that controls large pools of compute, storage, and networking resources throughout a datacenter, all managed through a dashboard that gives administrators control while empowering their users to provision resources through a web interface.

以上是官網(wǎng)對 OpenStack 的定義,OpenStack 對數(shù)據(jù)中心的計算僵闯、存儲和網(wǎng)絡(luò)資源進行統(tǒng)一管理卧抗。 由此可見,OpenStack 針對的是 IT 基礎(chǔ)設(shè)施鳖粟,是 IaaS 這個層次的云操作系統(tǒng)社裆。

OpenStack 已經(jīng)走過了 6 個年頭。 每半年發(fā)布一個版本向图,版本以字母順序命名泳秀,現(xiàn)在已經(jīng)到第 14 個版本 Newton(字母 N)。 OpenStack最初只有兩個模塊(服務(wù))榄攀,現(xiàn)在已經(jīng)有 20+(見下圖)嗜傅,每個模塊作為獨立的子項目開發(fā)。

image

作為 IaaS 層的云操作系統(tǒng)檩赢,OpenStack 為虛機提供并管理三大類資源:計算吕嘀、網(wǎng)絡(luò)和存儲。如下圖所示:

image

三贞瞒、OpenStack架構(gòu)

架構(gòu)能幫助我們站在高處看清楚事物的整體結(jié)構(gòu)偶房,避免過早地進入細節(jié)而迷失方向道媚。下圖是 OpenStack 的 Conceptual Architecture

image

中間菱形VM是虛擬機酪我,圍繞 VM 的那些長方形代表 OpenStack 不同的模塊(OpenStack 叫服務(wù),后面都用服務(wù)這個術(shù)語)逗扒,下面來分別介紹乒融。

Nova:管理 VM 的生命周期掰盘,是 OpenStack 中最核心的服務(wù)。
Neutron:為 OpenStack 提供網(wǎng)絡(luò)連接服務(wù)赞季,負責(zé)創(chuàng)建和管理L2愧捕、L3 網(wǎng)絡(luò),為 VM 提供虛擬網(wǎng)絡(luò)和物理網(wǎng)絡(luò)連接碟摆。
Glance:管理 VM 啟動鏡像晃财,Nova 創(chuàng)建 VM 時將使用 Glance 提供的鏡像。
Cinder:為 VM 提供塊存儲服務(wù)典蜕。Cinder 提供的每一個 Volume 在 VM 看來就是一塊虛擬硬盤断盛,一般用作數(shù)據(jù)盤。
Swift:提供對象存儲服務(wù)愉舔。VM 可以通過 RESTful API 存放對象數(shù)據(jù)钢猛。作為可選的方案,Glance 可以將鏡像存放在 Swift 中轩缤;Cinder 也可以將 Volume 備份到 Swift 中命迈。
Keystone:為 OpenStack 的各種服務(wù)提供認證和權(quán)限管理服務(wù)贩绕。簡單的說,OpenStack 上的每一個操作都必須通過 Keystone 的審核壶愤。
Ceilometer:提供 OpenStac k監(jiān)控和計量服務(wù)淑倾,為報警、統(tǒng)計或計費提供數(shù)據(jù)征椒。
Horizon:為 OpenStack 用戶提供一個 Web 的自服務(wù) Portal娇哆。

在上面的這些服務(wù)中,哪些是 OpenStack 的核心服務(wù)呢勃救? 核心服務(wù)就是如果沒有它碍讨,OpenStack 就跑不起來。 很顯然:

Nova 管理計算資源蒙秒,是核心服務(wù)勃黍。
Neutron 管理網(wǎng)絡(luò)資源,是核心服務(wù)晕讲。
Glance 為 VM 提供 OS 鏡像覆获,屬于存儲范疇,是核心服務(wù)益兄。
Cinder 提供塊存儲锻梳,VM怎么也得需要數(shù)據(jù)盤吧箭券,是核心服務(wù)净捅。
Swift 提供對象存儲,不是必須的辩块,是可選服務(wù)蛔六。
Keystone 認證服務(wù),沒它 OpenStack 轉(zhuǎn)不起來废亭,是核心服務(wù)国章。
Ceilometer 監(jiān)控服務(wù),不是必須的豆村,可選服務(wù)液兽。
Horizon 操作界面,也是必須的掌动。

再看OpenStack核心服務(wù)內(nèi)部的組成結(jié)構(gòu):
Logical Architecture

image

在 Logical Architecture 中四啰,可以看到每個服務(wù)又由若干組件組成。 以 Neutron 為例粗恢,包含:

image
  • Neutron Server柑晒、Neutron plugins 和 Neutron agents
  • Network provider
  • 消息隊列 Queue
  • 數(shù)據(jù)庫 Neutron Database

上面是 Logical Architecture,描述的是 Neutron 服務(wù)各個組成部分以及各組件之間的邏輯關(guān)系眷射。 而在實際的部署方案上匙赞,各個組件可以部署到不同的物理節(jié)點上佛掖。

OpenStack 本身是一個分布式系統(tǒng),不但各個服務(wù)可以分布部署涌庭,服務(wù)中的組件也可以分布部署芥被。 這種分布式特性讓 OpenStack 具備極大的靈活性、伸縮性和高可用性坐榆。 當然從另一個角度講撕彤,這也使得 OpenStack 比一般系統(tǒng)復(fù)雜,學(xué)習(xí)難度也更大猛拴。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末羹铅,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子愉昆,更是在濱河造成了極大的恐慌职员,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,406評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件跛溉,死亡現(xiàn)場離奇詭異焊切,居然都是意外死亡,警方通過查閱死者的電腦和手機芳室,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,732評論 3 393
  • 文/潘曉璐 我一進店門专肪,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人堪侯,你說我怎么就攤上這事嚎尤。” “怎么了伍宦?”我有些...
    開封第一講書人閱讀 163,711評論 0 353
  • 文/不壞的土叔 我叫張陵芽死,是天一觀的道長。 經(jīng)常有香客問我次洼,道長关贵,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,380評論 1 293
  • 正文 為了忘掉前任卖毁,我火速辦了婚禮揖曾,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘亥啦。我一直安慰自己炭剪,他們只是感情好,可當我...
    茶點故事閱讀 67,432評論 6 392
  • 文/花漫 我一把揭開白布禁悠。 她就那樣靜靜地躺著念祭,像睡著了一般。 火紅的嫁衣襯著肌膚如雪碍侦。 梳的紋絲不亂的頭發(fā)上粱坤,一...
    開封第一講書人閱讀 51,301評論 1 301
  • 那天隶糕,我揣著相機與錄音,去河邊找鬼站玄。 笑死枚驻,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的株旷。 我是一名探鬼主播再登,決...
    沈念sama閱讀 40,145評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼晾剖!你這毒婦竟也來了锉矢?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,008評論 0 276
  • 序言:老撾萬榮一對情侶失蹤齿尽,失蹤者是張志新(化名)和其女友劉穎沽损,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體循头,經(jīng)...
    沈念sama閱讀 45,443評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡绵估,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,649評論 3 334
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了卡骂。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片国裳。...
    茶點故事閱讀 39,795評論 1 347
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖全跨,靈堂內(nèi)的尸體忽然破棺而出缝左,到底是詐尸還是另有隱情,我是刑警寧澤螟蒸,帶...
    沈念sama閱讀 35,501評論 5 345
  • 正文 年R本政府宣布盒使,位于F島的核電站,受9級特大地震影響七嫌,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜苞慢,卻給世界環(huán)境...
    茶點故事閱讀 41,119評論 3 328
  • 文/蒙蒙 一诵原、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧挽放,春花似錦绍赛、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,731評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至纯出,卻和暖如春蚯妇,著一層夾襖步出監(jiān)牢的瞬間敷燎,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,865評論 1 269
  • 我被黑心中介騙來泰國打工箩言, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留硬贯,地道東北人。 一個月前我還...
    沈念sama閱讀 47,899評論 2 370
  • 正文 我出身青樓陨收,卻偏偏與公主長得像饭豹,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子务漩,可洞房花燭夜當晚...
    茶點故事閱讀 44,724評論 2 354

推薦閱讀更多精彩內(nèi)容

  • 本文遵循「知識共享許可協(xié)議 CC-BY-NC-SA 4.0 International」拄衰,未經(jīng)作者書面許可,不允許...
    laiwei閱讀 11,793評論 1 24
  • 第一章 OpenStack基礎(chǔ) OpenStack管理的資源及提供的服務(wù)OpenStack做為一個操作系統(tǒng)饵骨,...
    sgt_tiger閱讀 12,918評論 4 72
  • Nova Nova肾砂,即計算服務(wù),是OpenStack計算的彈性控制器宏悦。Nova可以說是整個云平臺最重要的組件镐确,Op...
    邵勝奧閱讀 4,161評論 0 8
  • OpenStack簡介 OpenStack版本發(fā)展 OpenStack版本系列字母以A~Z命名,從2010年發(fā)布的...
    糯米藕閱讀 5,032評論 0 17
  • (寢室的人已經(jīng)散光饼煞,不必再擔(dān)心這題目被嘲笑) 帕斯卡爾說: “人是一根有思想的葦草源葫。是自然界最脆弱的東西;但他是一...
    想飛的俞閱讀 352評論 0 1