關(guān)于磁盤IO

????????頻繁的磁盤IO操作可能會給程序或者系統(tǒng)帶來意想不到的問題燥爷。工作中我們可能會碰到在壓縮或者寫大體積文件時(shí),另一個(gè)同學(xué)連接上終端后敲命令會很卡,這種現(xiàn)象非常明顯萎津。但如果程序中頻繁使用磁盤IO葱色,產(chǎn)生的問題就不一定能這么明顯的定位到了递宅。

背景

? ? ? ? 個(gè)人負(fù)責(zé)的一個(gè)組件其中有針對監(jiān)聽指定事件,并在獲取到事件時(shí)進(jìn)行截屏然后回傳服務(wù)端的需求苍狰。由于運(yùn)行環(huán)境特殊的原因恐锣,程序是以system角色跑在windows中,無法直接獲取當(dāng)前用戶的桌面信息舞痰,只能寫一個(gè)截屏程序土榴,并基于CreateProcessAsUser系統(tǒng)接口來調(diào)用,而此接口返回值只有一個(gè)error類型响牛,無法返回其他類型玷禽。

? ? ? ? 之前初始版本實(shí)現(xiàn)時(shí)是在調(diào)截屏程序時(shí)傳遞一個(gè)uuid,截屏程序生成截屏文件呀打,以uuid為文件名直接落盤矢赁,服務(wù)端在獲取接口返回后等待截屏文件落地后讀取截屏內(nèi)容后再發(fā)送出去,由于圖片寫入磁盤需要消耗一定時(shí)間贬丛,服務(wù)端只能等待一段時(shí)間后再判斷截屏文件是否生成撩银。

? ? ? ? 實(shí)際應(yīng)用后經(jīng)測試發(fā)現(xiàn),win2008豺憔、win7上多次觸發(fā)截屏额获,都能獲取完整渲染的圖像文件够庙,而win10中總有一定記錄生成的圖片顯示的不全,經(jīng)過多方排查后一直沒找到確切原因抄邀。

? ? ? ? 在一次優(yōu)化另一個(gè)模塊的磁盤io占用后耘眨,不經(jīng)意間發(fā)現(xiàn),新版本的程序在win10出現(xiàn)截屏不全的幾率已經(jīng)降低到1/15左右境肾,但偶爾還會出現(xiàn)剔难。那么這么一看,原因基本可以確定跟頻繁磁盤IO有關(guān)了(還有一方面因素奥喻,在相同資源配置下偶宫,win2008和win7系統(tǒng)的流暢度比win10要好的多)。截屏?xí)r要落盤环鲤,而獲取截屏數(shù)據(jù)時(shí)又要重新讀取纯趋,在事件產(chǎn)生的頻率高時(shí),因截屏產(chǎn)生的磁盤IO消耗就大了楔绞,極可能會出現(xiàn)圖片未生成完畢就被讀取的情況结闸。

? ? ? ? 那么驗(yàn)證思路就有了,盡量避免磁盤IO酒朵!經(jīng)過重新設(shè)計(jì)桦锄,新的實(shí)現(xiàn)方案是:服務(wù)端單獨(dú)啟動一個(gè)rpc server,用于單獨(dú)接收截屏程序上報(bào)的截屏數(shù)據(jù)請求蔫耽,然后正常下發(fā)截屏的調(diào)用结耀。截屏程序在收到指令后進(jìn)行截屏,截屏數(shù)據(jù)不寫入文件匙铡,而是申請一個(gè)buffer图甜,并直接寫入buffer,然后通過本地rpc調(diào)用服務(wù)端的方法回傳截屏數(shù)據(jù)鳖眼。服務(wù)端在啟動rpc server時(shí)單獨(dú)初始化一個(gè)帶過期的緩存黑毅,并用uuid為鍵存儲接收的截屏數(shù)據(jù)。下發(fā)截屏調(diào)用的模塊在發(fā)出截屏指令后直接去緩存中進(jìn)行查詢钦讳,查詢到后再根據(jù)業(yè)務(wù)邏輯需求發(fā)送出去矿瘦。

? ? ? ? ?新的截屏方案避免的截屏文件寫入磁盤及從磁盤讀取兩步IO操作,經(jīng)多次測試愿卒,win10環(huán)境下截屏渲染不全的現(xiàn)象未再出現(xiàn)缚去。

? ? ? ? 引用一個(gè)很經(jīng)典的對比圖

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市琼开,隨后出現(xiàn)的幾起案子易结,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,968評論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件搞动,死亡現(xiàn)場離奇詭異躏精,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)滋尉,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,601評論 2 382
  • 文/潘曉璐 我一進(jìn)店門玉控,熙熙樓的掌柜王于貴愁眉苦臉地迎上來飞主,“玉大人狮惜,你說我怎么就攤上這事÷凳叮” “怎么了碾篡?”我有些...
    開封第一講書人閱讀 153,220評論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長筏餐。 經(jīng)常有香客問我开泽,道長,這世上最難降的妖魔是什么魁瞪? 我笑而不...
    開封第一講書人閱讀 55,416評論 1 279
  • 正文 為了忘掉前任穆律,我火速辦了婚禮,結(jié)果婚禮上导俘,老公的妹妹穿的比我還像新娘峦耘。我一直安慰自己,他們只是感情好旅薄,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,425評論 5 374
  • 文/花漫 我一把揭開白布辅髓。 她就那樣靜靜地躺著,像睡著了一般少梁。 火紅的嫁衣襯著肌膚如雪洛口。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,144評論 1 285
  • 那天凯沪,我揣著相機(jī)與錄音第焰,去河邊找鬼。 笑死妨马,一個(gè)胖子當(dāng)著我的面吹牛挺举,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播身笤,決...
    沈念sama閱讀 38,432評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼豹悬,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了液荸?” 一聲冷哼從身側(cè)響起瞻佛,我...
    開封第一講書人閱讀 37,088評論 0 261
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后伤柄,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體绊困,經(jīng)...
    沈念sama閱讀 43,586評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,028評論 2 325
  • 正文 我和宋清朗相戀三年适刀,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了秤朗。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,137評論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡笔喉,死狀恐怖取视,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情常挚,我是刑警寧澤作谭,帶...
    沈念sama閱讀 33,783評論 4 324
  • 正文 年R本政府宣布,位于F島的核電站奄毡,受9級特大地震影響折欠,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜吼过,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,343評論 3 307
  • 文/蒙蒙 一锐秦、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧盗忱,春花似錦酱床、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,333評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至揖闸,卻和暖如春揍堕,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背汤纸。 一陣腳步聲響...
    開封第一講書人閱讀 31,559評論 1 262
  • 我被黑心中介騙來泰國打工衩茸, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人贮泞。 一個(gè)月前我還...
    沈念sama閱讀 45,595評論 2 355
  • 正文 我出身青樓楞慈,卻偏偏與公主長得像,于是被迫代替她去往敵國和親啃擦。 傳聞我的和親對象是個(gè)殘疾皇子囊蓝,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,901評論 2 345

推薦閱讀更多精彩內(nèi)容

  • 計(jì)算機(jī)主要由CPU、總線令蛉、I/O設(shè)備聚霜、內(nèi)存狡恬、硬盤等組成,見下圖: cpu由控制器(CU)和運(yùn)算器(ALU)組成蝎宇,相...
    舒小賤閱讀 2,110評論 0 1
  • 在本文中我將引用五篇有關(guān)disk io 的好文章來與讀者一起學(xué)習(xí)探討關(guān)于磁盤IO的事弟劲。我大概會提取一些關(guān)鍵點(diǎn),如果...
    沉思故事閱讀 1,676評論 1 0
  • 全新硬盤裝系統(tǒng)之前姥芥,必須對其進(jìn)行分區(qū)兔乞,硬盤分區(qū)初始化的格式主要有兩種:傳統(tǒng)的 MBR(Master Boot Re...
    rosy_dawn閱讀 3,301評論 0 1
  • 用兩張圖告訴你,為什么你的 App 會卡頓? - Android - 掘金 Cover 有什么料凉唐? 從這篇文章中你...
    hw1212閱讀 12,693評論 2 59
  • 分區(qū) 全新硬盤裝系統(tǒng)之前庸追,必須對其進(jìn)行分區(qū),硬盤分區(qū)初始化的格式主要有兩種:傳統(tǒng)的 MBR(Master Boot...
    rosy_dawn閱讀 7,598評論 0 2