天天看點

muduo 與 libevent2 吞吐量對比測試對象測試環境與測試方法測試結果

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

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

測試内容為:用戶端與伺服器運作在同一台機器,均為單線程,測試并發連接配接數為 1/10/100/1000/10000 時的吞吐量。

在同一台機器測試吞吐量的原因:

現在的 CPU 很快,即便是單線程單 TCP 連接配接也能把 Gigabit 以太網的帶寬跑滿。如果用兩台機器,所有的吞吐量測試結果都将是 100 MiB/s,失去了對比的意義。(或許可以對比哪個庫占的 CPU 少。)

在同一台機器上測試,可以在 CPU 資源相同的情況下,單純對比網絡庫的效率。也就是說單線程下,服務端和用戶端各占滿 1 個 CPU,比較哪個庫的吞吐量高。

單線程吞吐量測試,數字越大越好:

以上結果讓人大跌眼鏡,muduo 居然比 libevent 快 70%!跟蹤 libevent2 的源代碼發現,它每次最多從 socket 讀取 4096 位元組的資料 (證據在 buffer.c 的 evbuffer_read() 函數),怪不得吞吐量比 muduo 小很多。因為在這一測試中,muduo 每次讀取 16384 位元組,系統調用的成本效益較高。

buffer.c:#define EVBUFFER_MAX_READ      4096

為了公平起見,我再測了一次,這回兩個庫都發送 4096 位元組的消息。

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

    本文轉自 陳碩  部落格園部落格,原文連結:http://www.cnblogs.com/Solstice/archive/2010/09/05/muduo_vs_libevent.html,如需轉載請自行聯系原作者

繼續閱讀