

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、隨著多核處理器的迅猛普及,計算機編程模式由傳統(tǒng)串行編程模式向線程級并行編程模式轉(zhuǎn)變,以發(fā)揮出與核數(shù)量的增長相一致的實際效果。由于多核機器具有充足的計算資源和內(nèi)存容量,為了最大化資源的利用率,單臺多核機器往往并發(fā)運行多個多線程應(yīng)用,或者被多個運行多線程應(yīng)用的虛擬機所共享,使多線程應(yīng)用陷于CPU資源的競爭。例如,VMware于2010年發(fā)表的研究成果表明,在云計算環(huán)境下,平均每個處理器核被4個虛擬CPU(Virtual CPU,VCPU)時
2、分復(fù)用。在這種多核競爭環(huán)境下,多線程應(yīng)用中的無用線程(比如同步操作中的忙等線程)會浪費原本可以分配給有用線程的CPU資源,嚴重影響應(yīng)用的性能。因此,如何有效地利用寶貴的CPU資源,是使多線程應(yīng)用在多核競爭環(huán)境下高效執(zhí)行的關(guān)鍵問題。
首先,大量多線程應(yīng)用是基于單個程序多數(shù)據(jù)(Single Program Multiple Data,SPMD)編程模型實現(xiàn)的。SPMD編程模型由計算階段和強制障礙(Barrier)同步通信交替組成。
3、因此,多線程應(yīng)用的性能很大程度上取決于Barrier同步延時。但是,在多應(yīng)用并發(fā)執(zhí)行的環(huán)境下,Barrier同步延時會被極大延長。這是因為當前大多數(shù)操作系統(tǒng)無法感知到多線程應(yīng)用中的同步操作,以至于尚未到達Barrier同步點的線程沒有被及時調(diào)度。在Barrier同步期間,處于忙等狀態(tài)的線程可能會浪費CPU資源;當忙等線程被阻塞后,它們又可能將自己的CPU資源讓給其它應(yīng)用。這會極大地影響系統(tǒng)的整體吞吐量和公平性。為了解決這些問題,一種多核
4、競爭環(huán)境下的Barrier同步策略(代號為Tidon)將等待線程的時間片捐獻給它們被搶占、落后的姊妹線程。其中,姊妹線程是指來自相同應(yīng)用的線程。在這種方式下,等待線程可以直接輔助同步操作的完成。實驗結(jié)果表明,在多應(yīng)用并發(fā)執(zhí)行的環(huán)境下,Tidon能夠為Barrier密集型應(yīng)用帶來最高17.9倍的性能加速,同時不損害甚至提升非Barrier密集型應(yīng)用的性能,從而保障并發(fā)應(yīng)用之間的性能公平性。此外,Tidon在虛擬化環(huán)境下同樣有效。
5、 其次,平衡線程間的任務(wù)量是保障多線程應(yīng)用高效運行于多核平臺的重要手段。這是因為多線程應(yīng)用通常要等待所有線程完成分配的任務(wù)后,才算運行完畢。任務(wù)竊?。╓ork-stealing)技術(shù)是廣泛用于動態(tài)保障多線程應(yīng)用負載均衡的方法。但是,前人的工作證明,Work-stealing技術(shù)在諸如傳統(tǒng)多應(yīng)用并發(fā)和虛擬化環(huán)境這樣的競爭環(huán)境下,存在效率低下的問題。這是因為Work-stealing中的小偷線程會浪費CPU資源。盡管目前存在優(yōu)化Work-s
6、tealing在傳統(tǒng)多應(yīng)用并發(fā)環(huán)境下性能的方法,但是尚未存在改善Work-stealing在虛擬化環(huán)境下性能的有效方法。虛擬化引入的語義鴻溝和兩層調(diào)度問題,增加了虛擬化環(huán)境下Work-stealing優(yōu)化的困難。為此,一種虛擬化環(huán)境下面向Work-stealing的性能優(yōu)化方法(代號為Robinhood)在客戶操作系統(tǒng)和虛擬機監(jiān)控器這兩個層面,利用小偷線程的CPU資源來加速有用線程的執(zhí)行進度,以致于減少應(yīng)用的執(zhí)行時間。實驗結(jié)果表明,與C
7、ilk++和BWS(Balanced Work Stealing)相比,Robinhood能夠分別為Work-stealing帶來最高90%和72%的性能提升。
最后,數(shù)據(jù)并行應(yīng)用是云計算環(huán)境下的典型應(yīng)用。多核平臺強大的處理能力和迅猛的發(fā)展趨勢使其在數(shù)據(jù)并行應(yīng)用領(lǐng)域有著極為廣闊的前景。MapReduce作為最初針對集群平臺設(shè)計和實現(xiàn)的數(shù)據(jù)并行編程模型,亦被許多研究者證明可作為單機多核環(huán)境下易用、高性能的并行編程模型。與此同時,
8、隨著云計算環(huán)境下運行于單機多核平臺的虛擬機數(shù)量不斷增加,CPU資源變得越來越寶貴。但是,現(xiàn)有單機多核平臺上的MapReduce系統(tǒng)更多的關(guān)注于通用性而缺乏針對性,使其在某些應(yīng)用領(lǐng)域和計算需求下會產(chǎn)生不必要的開銷,以至于浪費CPU資源。為此,一種面向單機多核平臺的可定制MapReduce系統(tǒng)(代號為Peacock)通過建立一種應(yīng)用分類模型,將基于MapReduce的多線程應(yīng)用劃分為四種不同的類型,并為不同類型的應(yīng)用定制高效的執(zhí)行流程,從根
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 面向多線程應(yīng)用的多核Cache優(yōu)化研究.pdf
- 數(shù)據(jù)容錯的多核多線程投機方法研究.pdf
- 基于多核的多線程算法并行優(yōu)化.pdf
- 基于多核環(huán)境下的多線程并行程序設(shè)計方法研究.pdf
- linux利用多核多線程進行程序優(yōu)化
- linux利用多核多線程進行程序優(yōu)化
- 面向多線程應(yīng)用的Cache優(yōu)化策略及并行模擬研究.pdf
- 多核下可伸縮的多線程模型.pdf
- 多核同時多線程體系結(jié)構(gòu)研究.pdf
- 基于粒子群優(yōu)化算法的多核多線程系統(tǒng)任務(wù)調(diào)度研究.pdf
- 多線程程序數(shù)據(jù)競爭靜態(tài)檢測方法研究.pdf
- 面向多線程機制的軟件重構(gòu)方法研究與實現(xiàn).pdf
- 多核處理器中具有臨界區(qū)的多線程調(diào)度方法研究.pdf
- 基于多核多線程的梅西算法的研究和實現(xiàn).pdf
- 基于多線程應(yīng)用的異構(gòu)多核體系設(shè)計與實現(xiàn).pdf
- 基于IA32多核架構(gòu)的多線程程序性能的動態(tài)優(yōu)化.pdf
- 多線程程序數(shù)據(jù)競爭檢測和驗證方法研究.pdf
- 多核多線程處理器環(huán)境下軟件系統(tǒng)的設(shè)計與實現(xiàn).pdf
- 基于多核平臺的多線程動態(tài)二進制翻譯系統(tǒng)優(yōu)化框架.pdf
- 基于多核多線程技術(shù)的通信網(wǎng)仿真算法研究.pdf
評論
0/150
提交評論