- 相關(guān)推薦
機器學(xué)習(xí)的服務(wù)器調(diào)優(yōu)系統(tǒng)設(shè)計論文
當(dāng)代,論文常用來指進行各個學(xué)術(shù)領(lǐng)域的研究和描述學(xué)術(shù)研究成果的文章,簡稱之為論文。它既是探討問題進行學(xué)術(shù)研究的一種手段,又是描述學(xué)術(shù)研究成果進行學(xué)術(shù)交流的一種工具。下面是小編整理的機器學(xué)習(xí)的服務(wù)器調(diào)優(yōu)系統(tǒng)設(shè)計論文,歡迎大家分享。
[摘要]
隨著計算機網(wǎng)絡(luò)的廣泛應(yīng)用,越來越多的網(wǎng)絡(luò)服務(wù)程序都要求服務(wù)器具有穩(wěn)定的性能以提供可靠的服務(wù)。本文提出了基于機器學(xué)習(xí)的服務(wù)器調(diào)優(yōu)系統(tǒng)的設(shè)計與實現(xiàn)方法,為提高服務(wù)器的可靠性及高效性提供了較好的解決方案。
[關(guān)鍵詞]
機器學(xué)習(xí);服務(wù)器調(diào)優(yōu);線程池
。壑袌D分類號]
TP181[文獻標(biāo)識碼]A[文章編號]1009—5349(2016)02-0133-01
一、線程池調(diào)優(yōu)系統(tǒng)總體設(shè)計
線程池調(diào)優(yōu)系統(tǒng)由四個模塊組成:線程池模塊、性能監(jiān)測模塊、支持向量機調(diào)優(yōu)模塊。線程池模塊負(fù)責(zé)線程池的創(chuàng)建與維護,任務(wù)隊列的任務(wù)管理等,并將任務(wù)隊列中的用戶任務(wù)取出放入線程池中進行執(zhí)行。性能監(jiān)測模塊負(fù)責(zé)對表征線程池性能的三個特征量吞吐量、任務(wù)運算時間和任務(wù)阻塞時間的監(jiān)測,作為測試樣本輸入支持向量機調(diào)優(yōu)模塊中。支持向量機調(diào)優(yōu)模塊則通過性能監(jiān)測模塊提供的測試樣本,得到所需的最佳線程池尺寸,并與當(dāng)前的線程池尺寸進行對比,最后調(diào)整線程池尺寸到最佳。
二、線程池模塊
線程池模塊主要負(fù)責(zé)線程池內(nèi)線程的創(chuàng)建、銷毀、構(gòu)造任務(wù)隊列,并將任務(wù)隊列中的用戶任務(wù)取入線程池中分配空閑線程來執(zhí)行。系統(tǒng)采用Win32的提供的線程庫,以面向?qū)ο笏枷雽崿F(xiàn)相關(guān)功能模塊。線程池模塊主要包括線程池類CPoolThread、任務(wù)隊列類CJobDequeue、線程類CThread以及同步類CMutex。線程類CThread最重要的一個方法是線程的創(chuàng)建方法CThread::Create()。線程創(chuàng)建方法采用了Win32線程庫提供的線程創(chuàng)建應(yīng)用程序接口CreateThread(Null,0,_ThreadEntry,this,0,&ThreadID)來實現(xiàn)。線程池類CThreadPool主要提供了一個數(shù)組變量m_list_thread來維護一個線程池,線程池內(nèi)的每個線程都存在了這個數(shù)組變量中,而具體的池內(nèi)線程的操作都交給了線程類CThread來完成。線程池類CThreadPool主要包括初始化線程池的初始化方法CThreadPool::InitInstance()來實現(xiàn)線程池內(nèi)所有線程的創(chuàng)建操作,具體通過CThread類的CThread::Create()方法來實現(xiàn)每個線程的創(chuàng)建。任務(wù)隊列類CJobQueue是線程池類的一個對象,維護了一個任務(wù)隊列數(shù)組列表m_normal_list,用戶任務(wù)經(jīng)過線程池類添加任務(wù)接口進入此數(shù)組列表中。任務(wù)隊列類通過隊列列表來維護管理等待中的用戶任務(wù)。同步類CMutex主要是為了實現(xiàn)程序中的某些互斥操作設(shè)立的,通過對私有變量m_lock調(diào)用WinAPI函數(shù)的WaitForSingleObject()與ReleaseMutex()來實現(xiàn)程序的加鎖與解鎖操作。
三、性能監(jiān)測模塊
性能監(jiān)測模塊主要是監(jiān)測表征線程池性能的三個特征量:吞吐量、任務(wù)運算時間和任務(wù)阻塞時間。由于吞吐量是監(jiān)測用戶任務(wù)進入任務(wù)隊列的數(shù)量,因此,對吞吐量的監(jiān)測可以在任務(wù)隊列類中實現(xiàn)。而任務(wù)運算時間和任務(wù)阻塞時間直接是與線程的執(zhí)行任務(wù)相關(guān)的,因此,將這兩個量的監(jiān)測放入線程類中實現(xiàn)。性能監(jiān)測模塊對吞吐量的監(jiān)測方法。每當(dāng)有用戶任務(wù)通過線程池類進入任務(wù)隊列時,任務(wù)隊列將其成員變量m_tuntu進行加1操作,實現(xiàn)對吞吐量的實時更新。任務(wù)運算時間的監(jiān)測方法主要通過調(diào)用Windows提供的API函數(shù)GetThreadTimes添加至線程類中的Run方法中來實現(xiàn)。GetThreadTimes函數(shù)可以返回四個參數(shù):線程創(chuàng)建時間、線程退出時間、系統(tǒng)代碼運算時間和用戶代碼運算時間。因此,可以通過對系統(tǒng)代碼時間與用戶代碼時間求和來得到任務(wù)占用CPU的時間,也就是任務(wù)運算時間。具體做法是當(dāng)線程類中Run方法啟動用戶任務(wù)時,即調(diào)用此API函數(shù),獲得任務(wù)進入線程池時間;當(dāng)用戶任務(wù)運行結(jié)束時,再次調(diào)用此API函數(shù),即可獲得任務(wù)離開線程池時間,將二者做差即可得到任務(wù)占用CPU的運算時間。對任務(wù)阻塞時間的監(jiān)測方法的實現(xiàn)則相對麻煩一些,因為沒有直接測試任務(wù)阻塞時間的API函數(shù)。但是可以通過間接的方法來測量,即任務(wù)阻塞時間=任務(wù)執(zhí)行時間—任務(wù)運算時間。其中,任務(wù)執(zhí)行時間可以通過WindowsAPI函數(shù)getTickCount()來分別得到任務(wù)進入線程池與離開線程池時的CPU時鐘,從而做差就可以求出任務(wù)執(zhí)行時間;而任務(wù)運算時間也可以得到,因此再將兩者做差就可以得出最后的任務(wù)阻塞時間。具體做法同監(jiān)測任務(wù)運算時間時的做法,只是改變了監(jiān)測的API函數(shù)。
四、支持向量機調(diào)優(yōu)模塊
根據(jù)支持向量機調(diào)優(yōu)模型,將支持向量機調(diào)優(yōu)模塊寫成線程類中的一個函數(shù)——調(diào)優(yōu)函數(shù)Tuning()。通過線程池類內(nèi)的成員變量m_tuntu、m_cmptm和m_blktm獲取當(dāng)前線程池性能數(shù)據(jù),輸入到支持向量機方法中得到最佳線程池尺寸。當(dāng)最佳線程池尺寸與當(dāng)前線程池尺寸不符時,需要對線程池的尺寸進行調(diào)整。當(dāng)需要增加線程池尺寸時,可以通過WindowsAPI函數(shù)CreateThread()來創(chuàng)建新線程;當(dāng)需要減小線程池尺寸時,可以通過調(diào)用函數(shù)TerminateThread()來銷毀空閑線程,最終達到所需的最佳線程池尺寸。
【參考文獻】
[1]董如意.基于二階段法的新型凸殼支持向量機研究[J].現(xiàn)代交際,2012(11).
【機器學(xué)習(xí)的服務(wù)器調(diào)優(yōu)系統(tǒng)設(shè)計論文】相關(guān)文章:
FPGA數(shù)據(jù)采集與回放系統(tǒng)設(shè)計論文04-24
解析科技競賽賽務(wù)系統(tǒng)的設(shè)計與實現(xiàn)論文04-19
綜合布線系統(tǒng)設(shè)計項目教學(xué)模式應(yīng)用論文07-12
系統(tǒng)優(yōu)化與系統(tǒng)設(shè)計的教學(xué)07-08
關(guān)于景觀導(dǎo)視系統(tǒng)設(shè)計實踐教學(xué)方法的論文07-12
庫存管理系統(tǒng)論文07-24
控制系統(tǒng)論文12-07
物資管理系統(tǒng)論文08-06