• <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 吞吐量對比

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

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

            測試對象

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

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

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

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

            在同一臺機(jī)器測試吞吐量的原因:

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

            測試結(jié)果

            單線程吞吐量測試,數(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)樵谶@一測試中,muduo 每次讀取 16384 字節(jié),系統(tǒng)調(diào)用的性價比較高。

            buffer.c:#define EVBUFFER_MAX_READ      4096

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

            muduo_libevent_4k

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

            討論

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

            posted on 2010-09-05 19:14 陳碩 閱讀(3511) 評論(3)  編輯 收藏 引用 所屬分類: muduo

            評論

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

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

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

            你好,我想問問你這個性能分析圖是用什么畫出來的  回復(fù)  更多評論   

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

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

            <2025年8月>
            272829303112
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            導(dǎo)航

            統(tǒng)計

            常用鏈接

            隨筆分類

            隨筆檔案

            相冊

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            久久青青草视频| 久久久久99精品成人片试看| 久久九九免费高清视频| 人人狠狠综合久久亚洲高清| 久久亚洲sm情趣捆绑调教 | 久久精品青青草原伊人| 国产成人无码久久久精品一| 久久精品国产精品亚洲艾草网美妙| 久久亚洲中文字幕精品一区| 日韩一区二区久久久久久| 亚洲国产精品一区二区久久hs| 国产精品美女久久久免费| 免费无码国产欧美久久18| 777久久精品一区二区三区无码| 久久亚洲sm情趣捆绑调教| 久久97久久97精品免视看| 2021久久国自产拍精品| 91麻豆国产精品91久久久| 97超级碰碰碰碰久久久久| 久久中文骚妇内射| 久久人妻少妇嫩草AV蜜桃| 久久久受www免费人成| 亚洲国产精品久久| 嫩草影院久久国产精品| 国产精品毛片久久久久久久| 久久亚洲精品无码AV红樱桃| 久久综合久久美利坚合众国| 欧美久久天天综合香蕉伊| 久久天天躁狠狠躁夜夜2020| 久久精品国产清自在天天线| 伊人热人久久中文字幕| 9191精品国产免费久久| 亚洲国产精品久久久久久| 国产精品激情综合久久| 久久99精品久久久久久9蜜桃| 国产成人香蕉久久久久| 狠狠人妻久久久久久综合| 久久久精品久久久久久| 美女久久久久久| 日本欧美久久久久免费播放网| 久久偷看各类wc女厕嘘嘘|