李玉斌++謝忠福
摘 要:近年來,OpenStack是一種具有代表性的開源計算機平臺。但是由于其發(fā)展速度較快,在發(fā)展中很多劣勢也凸顯出來,具體的問題集中于以下幾方面:對于云平臺中的內(nèi)容監(jiān)管力度不夠、沒有更好的人工部署配置、容易出錯且效率偏低等。本研究主要從計算機構(gòu)件與管理的關(guān)鍵性技術(shù)為研究重點,主要解決OpenStack平臺管理上的不足之處,并設(shè)計以O(shè)penStack云管理為主的平臺系統(tǒng),先要以調(diào)用API應(yīng)用程序為管理操作要點,然后根據(jù)腳本檢測的方式對功能模塊進行重點檢測,最后在完成部署以后集中編寫集群擴展模塊。
關(guān)鍵詞:開元云基礎(chǔ);平臺;OpenStack;安裝
DOI:10.16640/j.cnki.37-1222/t.2017.24.128
云計算機是信息產(chǎn)業(yè)發(fā)展的新趨勢,在很多商業(yè)領(lǐng)域內(nèi)已經(jīng)取得較好的應(yīng)用效果。根據(jù)當(dāng)前的市場調(diào)研情況能獲悉,截止到2016年底云計算市場規(guī)模現(xiàn)在已經(jīng)達到了140億美元。這一數(shù)字在將來一段時間內(nèi)還會持續(xù)遞增,預(yù)計到2020年能達到1320億美元的產(chǎn)值。在開源領(lǐng)域內(nèi)很多技術(shù)的研究主要是為數(shù)據(jù)提供更合理的解決方案。在09年谷歌公司提供開發(fā)引擎,已然成為云計算的平臺服務(wù)終端系統(tǒng),其中具有代表性的開源平臺分別是OpenShift和CloudFoundary。
1 OpenStack開源云平臺的概述
(1)OpenStack云平臺。OpenStack的研發(fā)者為NASA與Rackspace,其是以Apache許可證授權(quán)的開放性源代碼項目。目前OpenStack的應(yīng)用受到了業(yè)內(nèi)廠商的大力支持,得到了非??焖俚陌l(fā)展。OpenStack并非是一個特有的軟件,而是做為一個專業(yè)的云平臺管理項目而存在的。OpenStack的組件包括了六個部分,通過各個組件之間的組合來執(zhí)行具體的工作。OpenStack誕生于2010年,并且達到了每半年更新一個版本的速度。其最大的特點便是具有非常強的開放性以及靈活性,對于后端技術(shù)的支持程度非常高,每一個模塊都可以與多種后端技術(shù)進行對接并良好運行,根據(jù)不同的選擇,可以進行多種模式的對接。當(dāng)前OpenStack的整體架構(gòu)依然在不斷的變化,技術(shù)的革新帶來了非常多的新組件。
(2)平臺架構(gòu)。OpenStack做為Iaas系統(tǒng)的一種,能夠非常良好的與Amazon EC2進行兼容。由于技術(shù)的不斷進步,各項技術(shù)的更新速度非???,OpenStack始終處于更新組件的過程之中,不斷擴充各類新組件以完善功能。各個模塊之間的信息具有嚴(yán)格的區(qū)分性,并不能進行模塊之間的信息共享,模塊之間的信息交互只能通過中間件進行。因此,不同的模塊在運行時,可以處于任何一臺服務(wù)器上,而沒有強制性要求。
(3)支持虛擬技術(shù)。云計算的基礎(chǔ)是分布式計算以及虛擬技術(shù),虛擬技術(shù)能夠非常有效的幫助云計算平臺存在于網(wǎng)絡(luò)與現(xiàn)實之中。當(dāng)前應(yīng)用最為廣泛的集中虛擬技術(shù)分別是Xen、KVM、VMWare、LXC和openVZ。OpenStack對于虛擬技術(shù)的支持程度相當(dāng)強,以上所有的主流虛擬技術(shù)都在其支持的范圍之內(nèi)。
2 安裝實現(xiàn)
(1)總體設(shè)計。云管理平臺包含了很多模塊,譬如資源創(chuàng)建與管理、安全管理以及備份恢復(fù)等等。整體開發(fā)需要利用Java語言在Linux系統(tǒng)下進行,整體設(shè)計結(jié)構(gòu)如圖1所示。
資源創(chuàng)建:云計算平臺所要計算的資源主要有四大類:1)虛擬機,2)存儲,3)網(wǎng)絡(luò),4)物理主機。同時為多個租戶進行計算服務(wù)時,其工作包括了主機域、工作組等相關(guān)管理規(guī)則的創(chuàng)建。對于各類相關(guān)資源的計算工作,云管理平臺主要通過對OpenStack當(dāng)中所提供的Rest API進行調(diào)用,從而實現(xiàn)目的。譬如在創(chuàng)建虛擬機的過程中,便需要調(diào)用Nova API,從而達到對Libvirt API的調(diào)用,以及nova-schedullar模塊的調(diào)用,同時也對計算節(jié)點的nova-compute模塊達到調(diào)用的目的,從而完成創(chuàng)建虛擬機的工作;在創(chuàng)建卷存儲工作時,需要調(diào)用Cinder模塊的API來完成。
資源監(jiān)測:資源監(jiān)測是平臺當(dāng)中不可或缺的重要組成部分,其能夠有效的對OpenStack當(dāng)中的所有環(huán)節(jié)進行監(jiān)測,及時發(fā)現(xiàn)服務(wù)組件的運行故障。
(2)構(gòu)建PssS平臺。通常來說IaaS為企業(yè)的私有云提供最為基礎(chǔ)的設(shè)施資源,開發(fā)者利用PaaS進行遠(yuǎn)程部署工作,從而實現(xiàn)對于應(yīng)用程序的有效管理。OpenStack在企業(yè)私有云的環(huán)境下運行時,僅僅能夠提供非常有限的一部分基礎(chǔ)設(shè)施資源,在OpenStack當(dāng)中資源的計算需要通過虛擬機的形式才可以為用戶提供服務(wù)。而對于普通用戶而言,很難用比較簡單的方式和操作完成自己的使用目的。并且虛擬機能夠?qū)⒂嬎愫痛鎯Φ却罅抠Y源形成一個固定的集合,從而使得資源在利用上無法得到較高的利用率,造成了很大的浪費。
基于OpenStack建立PaaS應(yīng)用時,需要利用云計算以及PaaS管理等等多方面的技術(shù)。PaaS平臺架構(gòu):在進行PaaS平臺架構(gòu)時,需要服務(wù)器、網(wǎng)絡(luò)設(shè)備以及存儲設(shè)備等硬件,OpenStack提供了資源架構(gòu),針對不同的資源可以進行有效的計算,同時還提供了全套的服務(wù)組件,使得PaaS在部署時可以利用OpenStack的虛擬資源完成。
(3)OpenShift平臺架構(gòu)。OpenShift的功能單元主要由兩部分組成,分別是Broker節(jié)點與Node節(jié)點,這兩個單元可以是物理主機,也可以是虛擬機,他們之間的信息交互,需要通過消息隊列這項服務(wù)實現(xiàn)。
Broker節(jié)點是重要的控制節(jié)點,能夠有效的對其他節(jié)點進行管理。用戶的登錄、DNS以及應(yīng)用程序的運行狀態(tài)等等都受到其管轄??蛻羧粝肱cBroker進行信息交流,就必須要通過Web控制帶等等第三方媒介,而無法直接與Broker進行直接的信息交互。
Node節(jié)點的主要作用便是對用戶的程序進行存儲,其功能的實現(xiàn)需要依靠Gear和Cartridges這兩個功能組件來完成。其中Gear的主要作用是存放用戶的軟件和硬件資源。OpenShift可以有效的兼容多種Gear,并允許用戶進行只有選擇。Cartridges套件的主要功能是為用戶所使用的程序提供各類支持,譬如編程語言的支持或者數(shù)據(jù)庫的相關(guān)支持等等。
3 結(jié)語
本文主要以云計算與管理為背景,研究開源云平臺OpenStack設(shè)計中實現(xiàn)的資源管理平臺開發(fā)系統(tǒng)。在專用化水平受限的情況下,工
(下轉(zhuǎn)第145頁)
(上接第142頁)
作中很多不足之處出現(xiàn),具體的工作展望如下:相較于OpenStack,開源PaaS平臺的發(fā)布時間有限,其中有關(guān)OpenShift的研究也相較于OpenStack少很多,關(guān)于他們的研究內(nèi)容還很少,研究深度也不足,多是停留在部署測試上,其實對于二次開發(fā)與優(yōu)化還有很多待優(yōu)化。在云計算管理方面,以資源監(jiān)測構(gòu)建數(shù)據(jù)信息平臺,為了便于研究故障處理與虛擬遷移,就需要先優(yōu)化云管理平臺。
參考文獻:
[1]李劍平.基于單節(jié)點單網(wǎng)卡環(huán)境的OpenStack平臺搭建[J].電腦知識與技術(shù),2014(23):45-47.
[2]龔進峰,曹健,袁大宏.基于OpenStack的云計算環(huán)境關(guān)鍵問題研究[J].電力系統(tǒng)自動化,2015(30):78-79.
[3]吳松飛.開源云計算管理平臺技術(shù)在電信運營商私有云建設(shè)中的應(yīng)用研究[J].電信科學(xué),2013(14):34-36.
作者簡介:李玉斌(1982-),男,貴州凱里人,工學(xué)碩士,副教授,主要研究方向:微電子技術(shù)、物聯(lián)網(wǎng)技術(shù)、大數(shù)據(jù)應(yīng)用。endprint