- 相關(guān)推薦
一種基于服務(wù)選取的SBS云資源優(yōu)化分配方式的論文
云計(jì)算的資源彈性分配特性允許企業(yè)和政府等組織按照實(shí)際需求購(gòu)買資源,使其逐漸成為分布式軟件系統(tǒng)的主要部署平臺(tái)[1,2].隨著軟件規(guī)模和復(fù)雜性的迅速增長(zhǎng),大部分分布式軟件系統(tǒng)開始采用面向服務(wù)的體系架構(gòu)(service-oriented architecture,簡(jiǎn)稱 SOA),進(jìn)而具備可靈活配置、動(dòng)態(tài)重構(gòu)、維護(hù)難度低等特點(diǎn).這類基于 SOA泛型開發(fā)的軟件系統(tǒng)也稱作基于服務(wù)的軟件系統(tǒng)(service-based software system,簡(jiǎn)稱 SBS)[3].SBS 可表示成一個(gè)由一系列組件服務(wù)根據(jù)不同組合規(guī)則(如順序結(jié)構(gòu)、循環(huán)結(jié)構(gòu)、并行結(jié)構(gòu)等)構(gòu)成的業(yè)務(wù)流程,其中,各組件服務(wù)用于完成特定功能,而組合規(guī)則則定義了組件服務(wù)之間的交互關(guān)系.為了處理用戶請(qǐng)求,需要將各組件服務(wù)初始化為相應(yīng)的服務(wù)實(shí)例,并部署到云環(huán)境中分配有一定數(shù)量資源的虛擬機(jī)上. 由于云資源的按需付費(fèi)模式,應(yīng)用提供商在部署 SBS 時(shí),通常希望以最少的資源滿足與應(yīng)用消費(fèi)者之間達(dá)成的服務(wù)水平協(xié)議(service level agreement,簡(jiǎn)稱 SLA)[4],其中描述了關(guān)于服務(wù)質(zhì)量(quality of service,簡(jiǎn)稱 QoS)屬性的約束,如響應(yīng)時(shí)間、吞吐量和可靠性等.實(shí)際上,云服務(wù)提供商的資源并不是無(wú)限的,如果應(yīng)用的資源需求量過(guò)大,則當(dāng)前云資源的狀態(tài)可能無(wú)法滿足其需要.因此,面向全局成本優(yōu)化目標(biāo)的 SBS 資源分配策略(即,各個(gè)組件服務(wù)的資源分配量)既要避免SLA違例,又要滿足當(dāng)前云環(huán)境可用資源狀態(tài)的約束,分配策略的好壞直接影響 SBS 運(yùn)行時(shí)的環(huán)境適應(yīng)能力.
目前,針對(duì) SBS 的云資源分配量計(jì)算問(wèn)題尚未提出有效的分配方法,主要依賴應(yīng)用提供商的手工分配.對(duì)于結(jié)構(gòu)簡(jiǎn)單的應(yīng)用,如單層應(yīng)用或者線性多層應(yīng)用,可以比較容易地根據(jù)運(yùn)行經(jīng)驗(yàn)手工確定應(yīng)用(每層)的最少資源分配量.在手工分配資源方法中,主要通過(guò)反復(fù)嘗試為 SBS 各組件服務(wù)分配不同資源量,即,產(chǎn)生不同測(cè)試用例,然后從中選取滿足SLA約束且資源成本最小的資源分配策略.然而在資源眾多的云環(huán)境中,對(duì)于任意組件服務(wù)往往存在大量不同資源分配量,進(jìn)而導(dǎo)致測(cè)試用例的組合爆炸問(wèn)題,此時(shí),手工分配方法是不現(xiàn)實(shí)的. SBS 云資源的手工分配,本質(zhì)上是通過(guò)不斷嘗試一定數(shù)量的測(cè)試用例來(lái)確定最優(yōu)資源分配策略的過(guò)程,因此可根據(jù)基于搜索的軟件工程(search-based software engineering,簡(jiǎn)稱 SBSE)[6]思想將其轉(zhuǎn)換為一個(gè)最優(yōu)化問(wèn)題,并采用元啟發(fā)式搜索算法求解.分析可知,為 SBS
各組件服務(wù)確定最佳資源分配量類似于服務(wù)選取問(wèn)題中為抽象服務(wù)選擇最優(yōu)具體服務(wù)的過(guò)程[7],其中,SBS 對(duì)應(yīng)組合服務(wù)流程,組件服務(wù)對(duì)應(yīng)抽象服務(wù),其可能的資源分配量對(duì)應(yīng)備選具體服務(wù).由于服務(wù)選取是一種面向全局目標(biāo)求解帶約束的組合優(yōu)化問(wèn)題的有效手段,因此本文提出將 SBS 云資源的優(yōu)化分配問(wèn)題轉(zhuǎn)換成為一個(gè)服務(wù)選取問(wèn)題來(lái)進(jìn)行求解.然而,如何將資源劃分為組件服務(wù)的備選具體服務(wù),是一個(gè)必須解決的難點(diǎn).同時(shí),與基本的服務(wù)選取問(wèn)題不同,求解 SBS 最優(yōu)資源分配策略時(shí)要考慮哪些備選具體服務(wù)不能被同時(shí)選取,以免違反可用資源狀態(tài)的約束.
針對(duì)上述問(wèn)題,為了確定使 SBS 整體資源成本最小的資源分配策略,假設(shè)資源可以細(xì)粒度分配[8],并且能夠獲得云環(huán)境的當(dāng)前可用資源狀態(tài).本文根據(jù)不同資源狀態(tài)對(duì)應(yīng)不同組件服務(wù)性能的特點(diǎn),首先通過(guò)資源劃分方法獲取當(dāng)前可用資源狀態(tài)下組件服務(wù)可能的資源分配量,并利用性能模型和資源定價(jià)模型分別計(jì)算相應(yīng)的組件服務(wù)性能與資源成本,進(jìn)而生成組件服務(wù)的備選邏輯服務(wù)集;然后,建立了一種基于服務(wù)選取的 SBS云資源優(yōu)化分配模型,并提出了求解該模型的混合遺傳算法.算法采用整數(shù)編碼方式對(duì)個(gè)體進(jìn)行十進(jìn)制編碼,同時(shí)引入了精英保留策略,從而保證算法的全局收斂性.另外,針對(duì)遺傳算法局部搜索能力差的不足,提出了基于局部搜索的變異算子.
實(shí)驗(yàn)結(jié)果表明:所提出的基于服務(wù)選取的 SBS 云資源優(yōu)化分配方法能夠有效地確定每個(gè)組件服務(wù)的最優(yōu)資源分配量,且與常用的求解整數(shù)規(guī)劃的分支定界法和基于精英保留策略的遺傳算法相比,本文的混合遺傳算法能夠在較大規(guī)模問(wèn)題上獲得資源成本較低的資源分配策略,且具有更快的收斂速度.另外,實(shí)驗(yàn)分析了不同資源劃分策略對(duì)解的質(zhì)量和算法求解效率的影響.本文的主要貢獻(xiàn)在于: (1) 提出了兩種能夠顯著縮小可行解搜索空間從而提高優(yōu)化問(wèn)題求解效率的資源劃分策略,包括等寬劃分策略和 Ent-MDLP 劃分策略; (2) 在此基礎(chǔ)上,根據(jù) SBSE 的思想構(gòu)建了一種云環(huán)境中基于服務(wù)選取的 SBS 資源優(yōu)化分配模型; (3) 設(shè)計(jì)了一種能夠有效求解該優(yōu)化模型的基于精英保留策略和局部搜索變異的混合遺傳算法. 本文第 1 節(jié)介紹相關(guān)工作.第 2 節(jié)描述云環(huán)境中基于服務(wù)選取的 SBS 資源優(yōu)化分配過(guò)程.第 3 節(jié)給出組件服務(wù)備選邏輯服務(wù)集的確定方法.第 4 節(jié)提出 SBS 云資源優(yōu)化分配模型及其求解算法.第 5 節(jié)對(duì)本文提出的優(yōu)化分配方法和求解算法進(jìn)行實(shí)驗(yàn)分析.最后總結(jié)全文并展望下一步工作. 1 相關(guān)工作 1.1 基于服務(wù)的應(yīng)用的云資源分配 現(xiàn)有工作主要從工作流和業(yè)務(wù)過(guò)程角度進(jìn)行云資源分配的研究.
文獻(xiàn)研究了一種云環(huán)境中基于控制論的自主動(dòng)態(tài)資源分配源預(yù)算約束的基礎(chǔ)上最大化自適應(yīng)應(yīng)用的 QoS,其中,自適應(yīng)應(yīng)用是由多個(gè)服務(wù)構(gòu)成的,但是沒(méi)有涉及到應(yīng)用的組成結(jié)構(gòu); 文獻(xiàn)采用云服務(wù)實(shí)現(xiàn)科學(xué)工作流,并且提出了一種基于粒子群優(yōu)化的資源調(diào)度方法,其考慮了數(shù)據(jù)傳輸和存儲(chǔ)代價(jià),并以最小化整體成本為目標(biāo); 文獻(xiàn)[10]研究了由多個(gè)工作流構(gòu)成的SBS的資源動(dòng)態(tài)分配方法,其優(yōu)化目標(biāo)是適應(yīng)資源狀態(tài)和QoS等的變化,從而最大化系統(tǒng)整體吞吐量; 文獻(xiàn)[11]提出了一種用于視頻監(jiān)控組合服務(wù)應(yīng)用的資源分配方法,該方法將虛擬機(jī)資源分配問(wèn)題映射為一個(gè)多維背包問(wèn)題,并且采用線性規(guī)劃和最佳適應(yīng)下降法進(jìn)行求解,其假設(shè)構(gòu)成應(yīng)用的每個(gè)媒體服務(wù)所需虛擬機(jī)的資源量是已知的,問(wèn)題的實(shí)質(zhì)是確定虛擬機(jī)在物理機(jī)上的優(yōu)化放置,目標(biāo)是使所占用的物理機(jī)數(shù)量最少;
文獻(xiàn)針對(duì)基于服務(wù)的應(yīng)用,將應(yīng)用性能目標(biāo)轉(zhuǎn)換成組件級(jí)別的目標(biāo),進(jìn)而確定各組件的資源需求,并使用多層應(yīng)用程序驗(yàn)證了方法有效性; 文獻(xiàn)[13]針對(duì)資源超額分配帶來(lái)的高成本問(wèn)題,提出了 ViePEP 彈性過(guò)程平臺(tái),其將業(yè)務(wù)過(guò)程管理系統(tǒng)與云資源管理系統(tǒng)的功能相結(jié)合,能夠調(diào)度整個(gè)過(guò)程或者單個(gè)任務(wù)以滿足服務(wù)等級(jí)目標(biāo),同時(shí)盡可能地降低資源成本和資源空閑率. 與這些工作不同的是: 本文研究的是在當(dāng)前云資源狀態(tài)下求解滿足 SLA 約束與資源成本優(yōu)化目標(biāo)的 SBS 資源分配策略,而以上工作主要針對(duì) QoS 優(yōu)化[810],如系統(tǒng)吞吐量,或者在最小化成本時(shí)未考慮 SLA 約束; 其次,本文采用了基于服務(wù)選取的方法解決云環(huán)境中 SBS 的資源優(yōu)化分配問(wèn)題; 最后,在確定 SBS 的各組件服務(wù)最優(yōu)資源分配量時(shí),考慮了資源有限情況下組件服務(wù)對(duì)資源的競(jìng)爭(zhēng),以及資源分配策略對(duì)云環(huán)境中各物理機(jī)可用資源狀態(tài)約束的滿足問(wèn)題. 1.2 基于搜索的軟件工程方法 本文本質(zhì)上是基于SBSE的思想,采用混合遺傳算法在SBS各組件服務(wù)的資源分配量空間中尋找能夠最小化資源成本,且滿足 SLA 約束以及云環(huán)境可用資源狀態(tài)約束的組件服務(wù)最優(yōu)資源分配量組合. SBSE 方法近年來(lái)被廣泛用于軟件設(shè)計(jì)、測(cè)試、需求工程、軟件項(xiàng)目管理等領(lǐng)域.
這些工作面向不同目標(biāo),通過(guò)定義合適的適應(yīng)度函數(shù)將軟件工程問(wèn)題轉(zhuǎn)換成基于搜索的最優(yōu)化問(wèn)題,并采用不同元啟發(fā)式搜索算法進(jìn)行求解.遺傳算法能夠有效求解 NP 問(wèn)題且實(shí)現(xiàn)相對(duì)簡(jiǎn)單,因此被大量運(yùn)用于基于 SBSE 方法的研究中.文獻(xiàn)采用遺傳算法研究了 QoS 感知的 Web 服務(wù)組合與服務(wù)選取問(wèn)題,表明該算法能夠在令人滿意的時(shí)間內(nèi)找到近似最優(yōu)解;文獻(xiàn)在考慮性能、可靠性以及代價(jià)等因素的基礎(chǔ)上,提出一種面向基于組件系統(tǒng)的軟件優(yōu)化及部署的遺傳算法;文獻(xiàn)從云用戶的角度,基于排隊(duì)論和歷史平均到達(dá)率研究最優(yōu)化 QoS 屬性的服務(wù)部署問(wèn)題,并提出了一種遺傳算法E3-R 進(jìn)行求解,該方法能夠減少冗余 QoS 目標(biāo);文獻(xiàn)[18]研究了如何在考慮云環(huán)境特性、部署架構(gòu)等條件下將由服務(wù)構(gòu)成的軟件組件遷移到云平臺(tái),并采用遺傳算法提高了在巨大解空間中搜
結(jié)束語(yǔ)
本文探討了一種適用于云環(huán)境中 SBS 的資源優(yōu)化分配方法.該方法基于 SBSE 思想,將資源優(yōu)化分配策略的確定轉(zhuǎn)換為服務(wù)選取問(wèn)題,從而采用混合遺傳算法搜索最優(yōu)解.在轉(zhuǎn)換問(wèn)題時(shí),定義了邏輯服務(wù)的概念,使得問(wèn)題不僅從形式上與服務(wù)選取相匹配,而且還考慮了云環(huán)境中的資源約束,因此更具實(shí)際應(yīng)用價(jià)值.實(shí)驗(yàn)證明了提出的模型和算法在確定 SBS 各組件服務(wù)資源分配量方面的有效性,且在遺傳算法中引入精英保留策略與局部搜索變異,對(duì)于全局收斂性和加快收斂速度具有顯著作用.另外,結(jié)果表明:提出的資源劃分策略對(duì)優(yōu)化算法求解效率和解的質(zhì)量均具有一定的影響,因此有助于在實(shí)際問(wèn)題中指導(dǎo)如何選取合適的資源分配粒度.本文擴(kuò)展了 SBSE 方法在云計(jì)算領(lǐng)域優(yōu)化 SBS 系統(tǒng)設(shè)計(jì)方面的具體應(yīng)用,且所得優(yōu)化結(jié)果對(duì)于提高 SBS 運(yùn)行時(shí)的環(huán)境適應(yīng)能力具有一定的幫助.在實(shí)際中,由于運(yùn)行環(huán)境的動(dòng)態(tài)性,如負(fù)載減少或增加、主機(jī)或網(wǎng)絡(luò)故障導(dǎo)致的資源不可用等,確定的最優(yōu)資源分配策略可能失效,因此在下一步工作中,有必要深入探索能夠適應(yīng)環(huán)境變化的SBS 云資源動(dòng)態(tài)分配方法.
【一種基于服務(wù)選取的SBS云資源優(yōu)化分配方式的論文】相關(guān)文章:
基于混合優(yōu)化策略的目標(biāo)分配優(yōu)化研究05-02
基于拍賣算法的目標(biāo)分配問(wèn)題優(yōu)化04-29
基于公平性原則的員工薪酬分配優(yōu)化策略論文04-27
基于宏觀經(jīng)濟(jì)優(yōu)化模型的區(qū)域污染負(fù)荷分配04-25
施工用混凝土輸送方式對(duì)比優(yōu)化的論文04-27
基于微觀經(jīng)濟(jì)學(xué)方法的網(wǎng)絡(luò)資源分配研究論文05-03
SBS防水卷材應(yīng)用的論文04-27