• <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>

            陳碩的Blog

            muduo 與 libevent2 吞吐量對(duì)比

            libevent 是一款非常好用的 C 語(yǔ)言網(wǎng)絡(luò)庫(kù),它也采用 Reactor 模型,正好可以與 muduo 做一對(duì)比。

            本文用 ping pong 測(cè)試來(lái)對(duì)比 muduo 和 libevent2 的吞吐量,測(cè)試結(jié)果表明 muduo 吞吐量平均比 libevent2 高 18% 以上,個(gè)別情況達(dá)到 70%。

            測(cè)試對(duì)象

            測(cè)試環(huán)境與測(cè)試方法

            測(cè)試環(huán)境與前文《muduo 與 boost asio 吞吐量對(duì)比》相同。

            我自己編寫(xiě)了 libevent2 的 ping pong 測(cè)試代碼,地址在 http://github.com/chenshuo/recipes/tree/master/pingpong/libevent/ 。由于這個(gè)測(cè)試代碼沒(méi)有使用多線程,所以本次測(cè)試只對(duì)比單線程下的性能。

            測(cè)試內(nèi)容為:客戶(hù)端與服務(wù)器運(yùn)行在同一臺(tái)機(jī)器,均為單線程,測(cè)試并發(fā)連接數(shù)為 1/10/100/1000/10000 時(shí)的吞吐量。

            在同一臺(tái)機(jī)器測(cè)試吞吐量的原因:

            • 現(xiàn)在的 CPU 很快,即便是單線程單 TCP 連接也能把 Gigabit 以太網(wǎng)的帶寬跑滿。如果用兩臺(tái)機(jī)器,所有的吞吐量測(cè)試結(jié)果都將是 100 MiB/s,失去了對(duì)比的意義。(或許可以對(duì)比哪個(gè)庫(kù)占的 CPU 少。)
            • 在同一臺(tái)機(jī)器上測(cè)試,可以在 CPU 資源相同的情況下,單純對(duì)比網(wǎng)絡(luò)庫(kù)的效率。也就是說(shuō)單線程下,服務(wù)端和客戶(hù)端各占滿 1 個(gè) CPU,比較哪個(gè)庫(kù)的吞吐量高。

            測(cè)試結(jié)果

            單線程吞吐量測(cè)試,數(shù)字越大越好:

            muduo_libevent_16k

            以上結(jié)果讓人大跌眼鏡,muduo 居然比 libevent 快 70%!跟蹤 libevent2 的源代碼發(fā)現(xiàn),它每次最多從 socket 讀取 4096 字節(jié)的數(shù)據(jù) (證據(jù)在 buffer.c 的 evbuffer_read() 函數(shù)),怪不得吞吐量比 muduo 小很多。因?yàn)樵谶@一測(cè)試中,muduo 每次讀取 16384 字節(jié),系統(tǒng)調(diào)用的性?xún)r(jià)比較高。

            buffer.c:#define EVBUFFER_MAX_READ      4096

            為了公平起見(jiàn),我再測(cè)了一次,這回兩個(gè)庫(kù)都發(fā)送 4096 字節(jié)的消息。

            muduo_libevent_4k

            測(cè)試結(jié)果表明 muduo 吞吐量平均比 libevent2 高 18% 以上。

            討論

            由于 libevent2 每次最多從網(wǎng)絡(luò)讀取 4096 字節(jié),大大限制了它的吞吐量。

            posted on 2010-09-05 19:14 陳碩 閱讀(3496) 評(píng)論(3)  編輯 收藏 引用 所屬分類(lèi): muduo

            評(píng)論

            # re: muduo 與 libevent2 吞吐量對(duì)比 2010-09-06 11:46 普派

            最多從網(wǎng)絡(luò)讀取 4096 字節(jié),大大限制了它的吞吐量  回復(fù)  更多評(píng)論   

            # re: muduo 與 libevent2 吞吐量對(duì)比 2010-09-09 14:42 ppx

            你好,我想問(wèn)問(wèn)你這個(gè)性能分析圖是用什么畫(huà)出來(lái)的  回復(fù)  更多評(píng)論   

            # re: muduo 與 libevent2 吞吐量對(duì)比 2010-09-09 20:07 陳碩

            @ppx
            Excel 2007 家庭版  回復(fù)  更多評(píng)論   

            <2025年6月>
            25262728293031
            1234567
            891011121314
            15161718192021
            22232425262728
            293012345

            導(dǎo)航

            統(tǒng)計(jì)

            常用鏈接

            隨筆分類(lèi)

            隨筆檔案

            相冊(cè)

            搜索

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            合区精品久久久中文字幕一区| 四虎国产精品免费久久久| 久久人妻少妇嫩草AV无码蜜桃| 色综合久久中文字幕综合网| 2020久久精品亚洲热综合一本| 久久天天躁狠狠躁夜夜avapp| 97久久精品午夜一区二区| 久久强奷乱码老熟女| 久久婷婷五月综合国产尤物app | 精品无码久久久久久久动漫| 91精品日韩人妻无码久久不卡 | 99久久免费国产精品热| 久久人人爽人人爽AV片| 69SEX久久精品国产麻豆| 偷窥少妇久久久久久久久| 99久久伊人精品综合观看| 亚洲va中文字幕无码久久| 国产香蕉97碰碰久久人人| 国产精品99久久99久久久| 久久综合色老色| 久久久久久国产a免费观看不卡 | 久久精品女人天堂AV麻| 国产亚洲综合久久系列| AV无码久久久久不卡蜜桃| 青春久久| 亚洲国产精品成人AV无码久久综合影院| 久久国产精品久久精品国产| 亚洲国产精品无码久久一线| 中文成人无码精品久久久不卡| 国产精品伊人久久伊人电影| 91精品国产色综合久久| 久久久久人妻精品一区二区三区| 国产精品久久婷婷六月丁香| 久久久久久久91精品免费观看| 久久99精品久久久久久水蜜桃| 成人国内精品久久久久影院VR | 伊人色综合久久天天网| 99精品国产免费久久久久久下载| 久久只有这里有精品4| 99久久精品免费看国产一区二区三区| 亚洲人成电影网站久久|