博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
muduo 与 libevent2 吞吐量对照
阅读量:6829 次
发布时间:2019-06-26

本文共 983 字,大约阅读时间需要 3 分钟。

libevent 是一款很好用的 C 语言网络库,它也採用 Reactor 模型,正好能够与 muduo 做一对照。

本文用 ping pong 測试来对照 muduo 和 libevent2 的吞吐量,測试结果表明 muduo 吞吐量平均比 libevent2 高 18% 以上,个别情况达到 70%。

測试对象

  • libevent 2.0.6-rc ()
  • muduo 0.1.1 ( SHA1 Checksum: a446ea8a22915f439063d2bc52eb2dc4b9caf92d

測试环境与測试方法

測试环境与前文《》同样。

我自己编写了 libevent2 的 ping pong 測试代码,地址在 。因为这个測试代码没有使用多线程,所以本次測试仅仅对照单线程下的性能。

測试内容为:client与server执行在同一台机器,均为单线程,測试并发连接数为 1/10/100/1000/10000 时的吞吐量。

在同一台机器測试吞吐量的原因:

  • 如今的 CPU 非常快,即便是单线程单 TCP 连接也能把 Gigabit 以太网的带宽跑满。假设用两台机器,全部的吞吐量測试结果都将是 100 MiB/s,失去了对照的意义。(也许能够对照哪个库占的 CPU 少。)
  • 在同一台机器上測试,能够在 CPU 资源同样的情况下,单纯对照网络库的效率。也就是说单线程下,服务端和client各占满 1 个 CPU,比較哪个库的吞吐量高。

測试结果

单线程吞吐量測试,数字越大越好:

muduo_libevent_16k

以上结果让人大跌眼镜,muduo 竟然比 libevent 快 70%!跟踪 libevent2 的源码发现,它每次最多从 socket 读取 4096 字节的数据 (证据在 buffer.c 的 evbuffer_read() 函数),怪不得吞吐量比 muduo 小非常多。由于在这一測试中,muduo 每次读取 16384 字节,系统调用的性价比較高。

buffer.c:#define EVBUFFER_MAX_READ      4096

为了公平起见,我再測了一次,这回两个库都发送 4096 字节的消息。

muduo_libevent_4k

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

讨论

因为 libevent2 每次最多从网络读取 4096 字节,大大限制了它的吞吐量。

转载地址:http://xvjkl.baihongyu.com/

你可能感兴趣的文章
android opengl es 2.0
查看>>
Java面试题
查看>>
Android 内存管理基本介绍
查看>>
欧拉函数
查看>>
支持开源,崇尚技术,追求真理,充实人生
查看>>
React—Native开发之 Could not connect to development server(Android)解决方法
查看>>
Android笔记之Snackbar的基本使用
查看>>
将博客搬至CSDN
查看>>
div宽高设置为百分比
查看>>
python multiprocess不能完全关闭socket的验证
查看>>
深入解读ESB与SOA的关系
查看>>
冒泡排序和选择排序
查看>>
Add Auto Login computer by Registy(自动登陆计算机通过增加注册表键值方法)
查看>>
Python 标准库中的装饰器
查看>>
数论12——浅谈指数与对数
查看>>
几种重要的网络演化模型
查看>>
override与重载(overload)的区别
查看>>
maven项目 jsp报错
查看>>
UVA699 dfs and map
查看>>
###20175311MyCP(课下作业,必做)
查看>>