青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

陳碩的Blog

muduo 與 boost asio 吞吐量對比

muduo (http://code.google.com/p/muduo) 是一個基于 Reactor 模式的 C++ 網絡庫,我在編寫它的時候并沒有以高并發高吞吐為主要目標,但出乎我的意料,ping pong 測試表明,muduo 吞吐量比 boost.asio 高 15% 以上。

測試對象

測試環境

硬件:DELL 490 工作站,雙路 Intel quad core Xeon E5320 CPU,16G 內存

操作系統:Ubuntu Linux Server 10.04.1 LTS x86_64

編譯器:g++ 4.4.3

測試方法

依據 asio 性能測試 http://think-async.com/Asio/LinuxPerformanceImprovements 的辦法,用 ping pong 協議來測試吞吐量。

簡單地說,ping pong 協議是客戶端和服務器都實現 echo 協議。當 TCP 連接建立時,客戶端向服務器發送一些數據,服務器會 echo 回這些數據,然后客戶端再 echo 回服務器。這些數據就會像乒乓球一樣在客戶端和服務器之間來回傳送,直到有一方斷開連接為止。這是用來測試吞吐量的常用辦法。

asio 的測試代碼取自 http://asio.cvs.sourceforge.net/viewvc/asio/asio/src/tests/performance/ ,未作更改。

muduo 的測試代碼在 0.1.1 軟件包內,路徑為 examples/pingpong/,代碼如 http://gist.github.com/564985 所示。

muduo 和 asio 的優化編譯參數均為 -O2 -finline-limit=1000

$ BUILD_TYPE=release ./build.sh  # 編譯 muduo 的優化版本

我主要做了兩項測試:

  • 單線程測試,測試并發連接數為 1/10/100/1000/10000 時的吞吐量。
  • 多線程測試,并發連接數為 100 或 1000,服務器和客戶端的線程數同時設為 1/2/3/4。(由于我家里只有一臺 8 核機器,而且服務器和客戶端運行在同一臺機器上,線程數大于 4 沒有意義。)

所有測試中,ping pong 消息的大小均為 16k bytes。測試用的 shell 腳本可從 http://gist.github.com/564985 下載。

測試結果

單線程測試的結果,數字越大越好:

single_thread

多線程測試的結果,數字越大越好:

multiple_thread_100conn

image007

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

討論

muduo 出乎意料地比 asio 性能優越,我想主要得益于其簡單的設計和簡潔的代碼。

asio 在多線程測試中表現不佳,我猜測其主要原因是測試代碼只使用了一個 io_service,如果改用“io_service per CPU”的話,性能應該有所提高。我對 asio 的了解程度僅限于能讀懂其代碼,希望能有 asio 高手編寫“io_service per CPU”的 ping pong 測試,以便與 muduo 做一個公平的比較。

ping pong 測試很容易實現,歡迎其他網絡庫(ACE、POCO、libevent 等)也能加入到對比中來,期待這些庫的高手出馬。

posted on 2010-09-04 16:30 陳碩 閱讀(4872) 評論(5)  編輯 收藏 引用 所屬分類: muduo

評論

# re: muduo 與 boost asio 吞吐量對比 2010-09-04 20:23 Cox

高人,期待后續大作  回復  更多評論   

# re: muduo 與 boost asio 吞吐量對比 2010-09-05 20:08 imjj

樓主的庫cmake 沒裝上,還沒測試
ACE 只實現了一個server,client 用的 asio 的
./client 127.0.0.1 $p 1 16384 $n 10
64位 win7 下 virtualbox 中的 ubuntu 10.04 32bit 桌面版,2 CPU 打開了 VT
ACE 是 5.8.1,reactor 模型, ACE_Dev_Poll_Reactor

5555 是 ACE 的服務器 6666 是 aiso 1.45 服務器

server:5555 sessions:1
941965312 total bytes written
941948928 total bytes read
server:6666 sessions:1
1029111808 total bytes written
1029095424 total bytes read

server:5555 sessions:10
2783215616 total bytes written
2783100928 total bytes read
server:6666 sessions:10
2227601408 total bytes written
2227503104 total bytes read

server:5555 sessions:100
1310179328 total bytes written
1308786688 total bytes read
server:6666 sessions:100
981581824 total bytes written
979976192 total bytes read

server:5555 sessions:1000
430227456 total bytes written
424837120 total bytes read
server:6666 sessions:1000
148946944 total bytes written
143015936 total bytes read

ACE 源碼如下
#include <ace/ACE.h>
#include <ace/Acceptor.h>
#include <ace/Task.h>
#include <ace/Svc_Handler.h>
#include <ace/SOCK_Stream.h>
#include <ace/SOCK_Acceptor.h>
#include <ace/INET_Addr.h>
#include <ace/Reactor.h>
#include <ace/Dev_Poll_Reactor.h>


int BLOCKSIZE = 16384;


class PingHandler : public ACE_Svc_Handler<ACE_SOCK_STREAM, ACE_NULL_SYNCH>
{
public:
PingHandler()
{
m_rbuff = NULL;
ACE_NEW(m_rbuff, ACE_Message_Block(BLOCKSIZE));
}
virtual ~PingHandler()
{
ACE_Message_Block::release(m_rbuff);
}

virtual int handle_input(ACE_HANDLE /*fd*/)
{
int ret = 0;
ssize_t bytes_required = m_rbuff->space();
ssize_t bytes_read = 0;
bytes_read = peer().recv(m_rbuff->wr_ptr(), m_rbuff->space());
if (bytes_read <= 0)
return -1;
m_rbuff->wr_ptr(bytes_read);
if (m_rbuff->space() == 0)
{
peer().send(m_rbuff->rd_ptr(), m_rbuff->length());
m_rbuff->reset();
}
return 0;
}

protected:
ACE_Message_Block * m_rbuff;
};


typedef ACE_Acceptor<PingHandler, ACE_SOCK_ACCEPTOR> PingAcceptor;

void usage()
{
ACE_DEBUG((LM_DEBUG,
ACE_TEXT("server <ip> <port> <threads> <blocksize>\n")));
}

int ACE_TMAIN(int argc, ACE_TCHAR * argv[])
{
if (argc != 5)
{
usage();
return 0;
}

ACE_Dev_Poll_Reactor dpr(1024);
ACE_Reactor r(&dpr);

const ACE_TCHAR * ip = argv[1];
u_short port = (u_short)ACE_OS::atoi(argv[2]);
int threads = ACE_OS::atoi(argv[3]);
BLOCKSIZE = ACE_OS::atoi(argv[4]);

PingAcceptor acceptor;
ACE_INET_Addr addr(port, ip);
if (acceptor.open(addr, &r) == -1)
{
ACE_DEBUG((LM_DEBUG, ACE_TEXT("faield:%p\n")));
return -1;
}

r.run_reactor_event_loop();
return 0;
}  回復  更多評論   

# re: muduo 與 boost asio 吞吐量對比 2010-09-06 11:59 普派

謝謝,收藏了  回復  更多評論   

# re: muduo 與 boost asio 吞吐量對比 2010-09-10 20:01 陳碩

@imjj
希望看到 client 端的 ACE 實現。  回復  更多評論   

# re: muduo 與 boost asio 吞吐量對比 2013-04-27 13:55 yayj

我修改了下asio的測試代碼,讓每個worker線程使用不同的io_service,但測試結果與只有一個io_service相比,沒有明顯的改善。所以可能不是io_service的數量問題。代碼鏈接https://gist.github.com/yayj/5472033, 有使用c++11的unique_ptr  回復  更多評論   

<2025年9月>
31123456
78910111213
14151617181920
21222324252627
2829301234
567891011

導航

統計

常用鏈接

隨筆分類

隨筆檔案

相冊

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲尤物在线| 欧美欧美全黄| 99综合在线| 日韩一级免费| 欧美无乱码久久久免费午夜一区| 欧美mv日韩mv国产网站app| 一区二区三区在线观看视频| 欧美一区二区视频免费观看| 亚洲影院色无极综合| 欧美日韩精品伦理作品在线免费观看| 一色屋精品视频免费看| 久久在线视频在线| 一本色道久久综合| 国产精品毛片高清在线完整版| 亚洲欧美另类久久久精品2019| 亚洲网站在线看| 亚洲国产精品久久久久秋霞不卡 | 欧美一区二区三区四区视频| 亚洲高清免费在线| 一本久久青青| 这里是久久伊人| 亚洲第一黄色| 午夜精品99久久免费| 亚洲二区在线| 亚洲人久久久| 最新69国产成人精品视频免费| 中文在线一区| 99一区二区| 欧美二区在线播放| 狼人社综合社区| 国产日韩欧美精品| 一区二区三区www| 日韩网站在线观看| 久久蜜桃香蕉精品一区二区三区| 亚洲精品免费一二三区| 欧美在线综合| 久久久久.com| 欧美日韩视频在线第一区| 亚洲卡通欧美制服中文| 亚洲精品一区二区三区不| 久久久久一本一区二区青青蜜月| 久久国产一区二区三区| 国产精品久久久久久亚洲毛片| 亚洲欧美日韩第一区| 欧美一级欧美一级在线播放| 国产精品欧美日韩一区| 亚洲午夜激情网页| 欧美在线视频全部完| 娇妻被交换粗又大又硬视频欧美| 久久国产免费看| 免费在线看一区| 亚洲精品一区二区在线| 欧美电影资源| 亚洲欧美偷拍卡通变态| 亚洲欧美日本另类| 一区在线播放视频| 欧美日精品一区视频| 亚洲免费观看| 日韩视频在线观看免费| 欧美午夜免费电影| 欧美~级网站不卡| 亚洲欧美国产精品桃花| 久久综合99re88久久爱| 亚洲一区3d动漫同人无遮挡| 永久免费毛片在线播放不卡| 欧美电影在线观看| 午夜精品久久久久久久99水蜜桃| 亚洲第一福利视频| 久久久国产91| 久久九九有精品国产23| 欧美在线观看网址综合| 亚洲少妇最新在线视频| 狠狠综合久久| 在线观看亚洲精品视频| 一本色道久久88综合亚洲精品ⅰ| 久久久久国内| 亚洲字幕一区二区| 亚洲一区二区黄| 99综合精品| 性娇小13――14欧美| 小黄鸭精品aⅴ导航网站入口| 亚洲免费在线观看视频| 亚洲欧美三级伦理| 欧美一区二区黄色| 蜜臀av一级做a爰片久久 | 一区二区三区四区国产| 一本一本久久| 欧美在线观看视频在线| 久久综合国产精品台湾中文娱乐网 | 亚洲国产精品高清久久久| 欧美高清在线播放| 9久草视频在线视频精品| 久久国产精品久久精品国产| 久久不射中文字幕| 久久久久久网址| 亚洲精品少妇网址| 久久成人羞羞网站| 欧美日韩系列| 91久久国产自产拍夜夜嗨| 亚洲自拍偷拍一区| 亚洲人精品午夜| 久久精品国产99| 国产精品你懂的在线| 亚洲人午夜精品免费| 久久另类ts人妖一区二区| 亚洲香蕉伊综合在人在线视看| 久久久噜噜噜久久人人看| 国产伦精品一区二区三区高清版 | 久久国产加勒比精品无码| 国产精品亚洲欧美| 亚洲国产成人tv| 国产区精品视频| 日韩视频一区二区三区| 国产日产亚洲精品| 一本大道久久精品懂色aⅴ | 亚洲激情视频在线| 亚洲永久免费精品| 99综合电影在线视频| 国产亚洲欧美一区二区| 亚洲国产欧洲综合997久久| 老色鬼精品视频在线观看播放| 欧美在线999| 亚洲成色www8888| 亚洲精品一级| 国产一区999| 亚洲剧情一区二区| 尤物yw午夜国产精品视频| 欧美激情1区2区3区| 欧美三级欧美一级| 久久综合网络一区二区| 欧美人与禽性xxxxx杂性| 午夜视频一区二区| 欧美精品一区二区三区蜜臀| 狠狠色狠色综合曰曰| 亚洲丁香婷深爱综合| 国产精品大片免费观看| 亚洲韩国精品一区| 国内精品免费在线观看| 宅男噜噜噜66国产日韩在线观看| 亚洲国产日韩一区| 久久精品二区三区| 欧美一区二区黄| 欧美日韩在线三区| 欧美一区二区三区播放老司机| 久久久噜噜噜久久久| 欧美国产大片| 久久久久国产精品一区三寸| 亚洲欧美日韩精品| 一本色道久久精品| 久久动漫亚洲| 亚洲激情成人| 久久久.com| 在线观看91精品国产麻豆| 在线亚洲免费| 国产欧美一区二区三区国产幕精品| 亚洲国产精品一区| 亚洲国产欧美一区| 免费观看在线综合色| 亚洲国产精品一区在线观看不卡 | 亚洲视频一区二区免费在线观看| 亚洲三级免费观看| 欧美午夜视频一区二区| 日韩西西人体444www| 欧美中文在线观看国产| 国产在线高清精品| 美日韩免费视频| 亚洲欧美国产精品桃花| 久久女同精品一区二区| 亚洲激情视频在线| 国产欧美日韩一级| 欧美高清在线一区二区| 性做久久久久久久免费看| 欧美1区3d| 欧美一区二区精品在线| 91久久极品少妇xxxxⅹ软件| 国产精品乱码一区二区三区| 久久久久久综合| 久久久久久久久久久久久女国产乱 | 亚洲一二三区在线观看| 国外成人性视频| 国产精品欧美在线| 欧美人与性动交a欧美精品| 久久成人羞羞网站| 欧美一级在线视频| 亚洲视频每日更新| 国产精品99久久久久久白浆小说| 亚洲高清色综合| 欧美大胆人体视频| 麻豆久久精品| 欧美国产在线观看| 免费在线观看一区二区| 免费黄网站欧美| 欧美成年人在线观看| 欧美国产日韩二区| 亚洲国产高清自拍| 亚洲精品在线免费| 亚洲一区www| 欧美一区二区在线视频| 理论片一区二区在线| 欧美激情在线免费观看|