999精品在线视频,手机成人午夜在线视频,久久不卡国产精品无码,中日无码在线观看,成人av手机在线观看,日韩精品亚洲一区中文字幕,亚洲av无码人妻,四虎国产在线观看 ?

基于機器學習的服務器調優系統設計

2016-06-06 09:18:24董如意孔慶賀洋陳凱
現代交際 2016年1期
關鍵詞:機器學習

董如意 孔慶 賀洋 陳凱

[摘要]隨著計算機網絡的廣泛應用,越來越多的網絡服務程序都要求服務器具有穩定的性能以提供可靠的服務。本文提出了基于機器學習的服務器調優系統的設計與實現方法,為提高服務器的可靠性及高效性提供了較好的解決方案。

[關鍵詞]機器學習 服務器調優 線程池

[中圖分類號]TP181 [文獻標識碼]A [文章編號]1009-5349(2016)02-0133-01

一、線程池調優系統總體設計

線程池調優系統由四個模塊組成:線程池模塊、性能監測模塊、支持向量機調優模塊。線程池模塊負責線程池的創建與維護,任務隊列的任務管理等,并將任務隊列中的用戶任務取出放入線程池中進行執行。性能監測模塊負責對表征線程池性能的三個特征量吞吐量、任務運算時間和任務阻塞時間的監測,作為測試樣本輸入支持向量機調優模塊中。支持向量機調優模塊則通過性能監測模塊提供的測試樣本,得到所需的最佳線程池尺寸,并與當前的線程池尺寸進行對比,最后調整線程池尺寸到最佳。

二、線程池模塊

線程池模塊主要負責線程池內線程的創建、銷毀、構造任務隊列,并將任務隊列中的用戶任務取入線程池中分配空閑線程來執行。系統采用Win32的提供的線程庫,以面向對象思想實現相關功能模塊。線程池模塊主要包括線程池類CPoolThread、任務隊列類CJobDequeue、線程類CThread以及同步類CMutex。

線程類CThread最重要的一個方法是線程的創建方法CThread::Create()。線程創建方法采用了Win32線程庫提供的線程創建應用程序接口CreateThread(Null,0,_ThreadEntry,this,0,&ThreadID;)來實現。線程池類CThreadPool主要提供了一個數組變量m_list_thread來維護一個線程池,線程池內的每個線程都存在了這個數組變量中,而具體的池內線程的操作都交給了線程類CThread來完成。線程池類CThreadPool主要包括初始化線程池的初始化方法CThreadPool::InitInstance()來實現線程池內所有線程的創建操作,具體通過CThread類的CThread::Create()方法來實現每個線程的創建。任務隊列類CJobQueue是線程池類的一個對象,維護了一個任務隊列數組列表m_normal_list,用戶任務經過線程池類添加任務接口進入此數組列表中。任務隊列類通過隊列列表來維護管理等待中的用戶任務。同步類CMutex主要是為了實現程序中的某些互斥操作設立的,通過對私有變量m_lock調用WinAPI函數的WaitForSingleObject()與ReleaseMutex()來實現程序的加鎖與解鎖操作。

三、性能監測模塊

性能監測模塊主要是監測表征線程池性能的三個特征量:吞吐量、任務運算時間和任務阻塞時間。由于吞吐量是監測用戶任務進入任務隊列的數量,因此,對吞吐量的監測可以在任務隊列類中實現。而任務運算時間和任務阻塞時間直接是與線程的執行任務相關的,因此,將這兩個量的監測放入線程類中實現。

性能監測模塊對吞吐量的監測方法。每當有用戶任務通過線程池類進入任務隊列時,任務隊列將其成員變量m_tuntu進行加1操作,實現對吞吐量的實時更新。

任務運算時間的監測方法主要通過調用Windows提供的API函數GetThreadTimes添加至線程類中的Run方法中來實現。GetThreadTimes函數可以返回四個參數:線程創建時間、線程退出時間、系統代碼運算時間和用戶代碼運算時間。因此,可以通過對系統代碼時間與用戶代碼時間求和來得到任務占用CPU的時間,也就是任務運算時間。具體做法是當線程類中Run方法啟動用戶任務時,即調用此API函數,獲得任務進入線程池時間;當用戶任務運行結束時,再次調用此API函數,即可獲得任務離開線程池時間,將二者做差即可得到任務占用CPU的運算時間。

對任務阻塞時間的監測方法的實現則相對麻煩一些,因為沒有直接測試任務阻塞時間的API函數.但是可以通過間接的方法來測量,即任務阻塞時間=任務執行時間-任務運算時間。其中,任務執行時間可以通過WindowsAPI函數getTickCount()來分別得到任務進入線程池與離開線程池時的CPU時鐘,從而做差就可以求出任務執行時間;而任務運算時間也可以得到,因此再將兩者做差就可以得出最后的任務阻塞時間。具體做法同監測任務運算時間時的做法,只是改變了監測的API函數。

四、支持向量機調優模塊

根據支持向量機調優模型,將支持向量機調優模塊寫成線程類中的一個函數——調優函數Tuning()。

通過線程池類內的成員變量m_tuntu、m_cmptm和m_blktm獲取當前線程池性能數據,輸入到支持向量機方法中得到最佳線程池尺寸。當最佳線程池尺寸與當前線程池尺寸不符時,需要對線程池的尺寸進行調整。當需要增加線程池尺寸時,可以通過WindowsAPI函數CreateThread()來創建新線程;當需要減小線程池尺寸時,可以通過調用函數TerminateThread()來銷毀空閑線程,最終達到所需的最佳線程池尺寸。

【參考文獻】

[1]董如意.基于二階段法的新型凸殼支持向量機研究[J].現代交際,2012(11).

責任編輯:張麗

猜你喜歡
機器學習
基于詞典與機器學習的中文微博情感分析
基于網絡搜索數據的平遙旅游客流量預測分析
時代金融(2016年27期)2016-11-25 17:51:36
前綴字母為特征在維吾爾語文本情感分類中的研究
科教導刊(2016年26期)2016-11-15 20:19:33
下一代廣播電視網中“人工智能”的應用
活力(2016年8期)2016-11-12 17:30:08
基于支持向量機的金融數據分析研究
基于Spark的大數據計算模型
基于樸素貝葉斯算法的垃圾短信智能識別系統
基于圖的半監督學習方法綜述
機器學習理論在高中自主學習中的應用
極限學習機在圖像分割中的應用
主站蜘蛛池模板: 亚洲欧洲日韩久久狠狠爱| 成人一级黄色毛片| 国产成人久久777777| 欧美日韩国产综合视频在线观看| 白浆免费视频国产精品视频| 2020精品极品国产色在线观看| 亚洲va在线∨a天堂va欧美va| 亚洲视频三级| 国产99欧美精品久久精品久久| 一区二区在线视频免费观看| 久热re国产手机在线观看| 亚洲日本中文综合在线| 四虎永久免费地址在线网站| 幺女国产一级毛片| 热思思久久免费视频| 久久亚洲AⅤ无码精品午夜麻豆| 一级不卡毛片| 在线看片国产| 67194亚洲无码| 视频一区视频二区中文精品| 中文字幕在线播放不卡| 国产精品爆乳99久久| 欧美精品亚洲二区| 久久这里只有精品8| 九九九精品成人免费视频7| 日韩精品免费一线在线观看| 国产成人一二三| 国产av剧情无码精品色午夜| 国产女人喷水视频| 精品人妻一区二区三区蜜桃AⅤ| 亚洲福利视频一区二区| 国产福利在线观看精品| 中文字幕啪啪| 日本91视频| 广东一级毛片| 日韩av在线直播| 国产成人综合在线视频| www.亚洲天堂| 欧美精品黑人粗大| 亚洲综合婷婷激情| 91免费国产在线观看尤物| 中文字幕人成乱码熟女免费| 亚洲欧美国产高清va在线播放| 一级一毛片a级毛片| 蝌蚪国产精品视频第一页| 精品久久人人爽人人玩人人妻| 国产菊爆视频在线观看| 青青青亚洲精品国产| 国产成人福利在线| 免费国产黄线在线观看| 综合成人国产| 91久久偷偷做嫩草影院免费看| 激情五月婷婷综合网| 国产国产人免费视频成18| 欧美日本在线| 中文字幕乱码中文乱码51精品| 日韩人妻无码制服丝袜视频| 亚洲精品不卡午夜精品| 欧美人与牲动交a欧美精品| 国内精品久久久久久久久久影视| 在线观看国产网址你懂的| 亚洲va在线∨a天堂va欧美va| 四虎成人在线视频| 国产精品无码翘臀在线看纯欲| 亚洲综合精品第一页| 欧美一区精品| 重口调教一区二区视频| 国产9191精品免费观看| 久久精品无码专区免费| 国产99视频精品免费视频7| 日韩激情成人| 熟女视频91| 国产第一福利影院| 国产成人91精品| 婷婷综合在线观看丁香| 亚洲欧美成人在线视频| 国产乱子伦手机在线| 久久这里只有精品8| 色婷婷成人网| 亚洲国产成人无码AV在线影院L| 国产一级无码不卡视频| 欧美色视频在线|