• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            posts - 200, comments - 8, trackbacks - 0, articles - 0

            writev和write性能比較(轉(zhuǎn))

            Posted on 2012-12-18 11:33 鑫龍 閱讀(1497) 評(píng)論(0)  編輯 收藏 引用 所屬分類: linux編程

            今天突然想比較一下 write() 和 writev() 的性能, 網(wǎng)上google了半天, 竟然沒有發(fā)現(xiàn)一點(diǎn)有關(guān)的數(shù)據(jù)信息, 自己就測試了一下。

            平臺(tái)如下:

            CentOS 5.2 Linux kernel 2.6.18-92.e15

            CPU: Intel(R) Pentium(R) 4 CPU 2.40GHz

            Disk: 7200 rpm

            測試的想法是: 對于writev(), 如果有10 個(gè)buffer, 并且buffer的大小是1kb,  那么我就先依次調(diào)用write() 10 次, 每次寫1KB 到同一個(gè)文件, 記錄下時(shí)間, 然后記錄下用writev()的時(shí)間。 最后, 以write()為baseline, 計(jì)算writev()所占的%, 如果%越小, 證明writev() 的性能就越好。

            做了兩組測試,

            第一組, 固定buffer 的個(gè)數(shù)(10, 100, 1000), 依次增加buffer的大小, 從1KB -- 1024KB, 數(shù)據(jù)如下, (基準(zhǔn)線為相應(yīng)write()的數(shù)據(jù))

            例如, 10 個(gè)buffer, 每個(gè)buffer size 是1KB。 write() 耗時(shí)0.092 ms, writev() 耗時(shí)0.098 ms, 圖中的數(shù)據(jù)即為 1.067 (write_v10, 1KB)

            圖一writev和write性能比較(轉(zhuǎn)) - 光明磊落 - 光明磊落的博客

             

            第二組, 固定buffer大?。?KB, 2KB, 8KB), 依次增加buffer的數(shù)目, 從 200 -- 8000, 數(shù)據(jù)如下 (基準(zhǔn)線為相應(yīng)write()的數(shù)據(jù))

            圖二

            writev和write性能比較(轉(zhuǎn)) - 光明磊落 - 光明磊落的博客

            第一組數(shù)據(jù)顯示:1.  隨著buffer的增大 ( > 64KB), writev()的性能開始跟write()持平; 2. 如果buffer的個(gè)數(shù)過小 , writev()的性能是低于write()的。 從圖一可以看到,  在buffer size 小于1024KB 時(shí), writev() 使用10 個(gè)buffer的性能要低于100 和1000。

            第二組數(shù)據(jù)顯示: 1. 當(dāng)保持buffer size一定情況下, 增加buffer的個(gè)數(shù) (< 2000), writev() 的性能穩(wěn)定在70%左右; 2. 增加buffer size, 將會(huì)降低writev()的性能。 當(dāng)buffer為8KB 時(shí), writev() 所用時(shí)間基本上都為相應(yīng)write()時(shí)間的80%, 性能的提高明顯不如1KB 和 2KB。3. 當(dāng)buffer的個(gè)數(shù)超過2000, 并且buffer size 大于2KB, writev()性能將遠(yuǎn)不如write()。

            結(jié)論:

            writev() 應(yīng)使用在small write intensive 的workload中, buffer size 應(yīng)控制在 2KB 以下, 同時(shí)buffer的數(shù)目不要超過IOV_MAX, 否則 writev() 并不會(huì)帶來性能的提高。 

             

            現(xiàn)在, 所要研究的問題是對于不同的workload, 如何快速的確定writev()中buffer的個(gè)數(shù)和大小, 從而達(dá)到較好performance。

            Saturday, May 09, 2009  8:50:48 PM

            精品国产婷婷久久久| 日产精品久久久一区二区| 久久精品国产清自在天天线| 久久99精品久久久久久秒播| 欧美亚洲国产精品久久高清| 久久精品国产精品亚洲毛片| 日本精品一区二区久久久| 精品免费久久久久久久| 一本久久综合亚洲鲁鲁五月天亚洲欧美一区二区 | 久久青青草原亚洲av无码app| 天天久久狠狠色综合| 麻豆精品久久久久久久99蜜桃| 久久免费视频观看| 久久亚洲欧美国产精品| 一级女性全黄久久生活片免费 | 久久久久亚洲AV成人片| 久久精品卫校国产小美女| 久久99精品久久久久久齐齐| 精品国产乱码久久久久久郑州公司 | 精品久久8x国产免费观看| 久久久久久精品免费看SSS| 久久九九免费高清视频| 国产精品无码久久综合| 久久夜色精品国产噜噜噜亚洲AV | 亚洲国产精品久久久久久| 国产亚洲色婷婷久久99精品| 久久久SS麻豆欧美国产日韩| 天天做夜夜做久久做狠狠| 久久国产影院| 久久久久亚洲精品无码网址| 国产福利电影一区二区三区久久久久成人精品综合 | 国产成人99久久亚洲综合精品| 99国产欧美精品久久久蜜芽| 国产精品久久国产精麻豆99网站| 日本久久久久亚洲中字幕| 久久精品中文无码资源站| 99精品国产在热久久无毒不卡| 狠色狠色狠狠色综合久久| 久久久综合九色合综国产| 国产成人香蕉久久久久| 久久婷婷五月综合色99啪ak|