免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1706 | 回复: 3
打印 上一主题 下一主题

[文件系统] sendfile的效率还不如read write? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-12-14 11:37 |只看该作者 |倒序浏览
    最近写了个测试程序,通过网络发送4G的文件到目标,分别用两种方式sandfile 和read 到本地BUFFER write到socket, 两种方式每次都是发送64K

测试环境:KVM虚拟出来的两台开发机,A和B,都是万兆网卡,2.6.32的内核,centos

结果发现通过TCP,A发送到B时sendfile的时间基本是read write的两倍,readwrite比较稳定基本在5秒左右,sandfile不太稳定 但基本在10多秒

但通过lo口发送给本地进程    sandfile明显比readwrite快很多 基本是2秒不到的时间

按理说sandfile相比较readwrite省去了几个数据拷贝的步骤,效率应该更高,但通过网络发送给远端的时候效率怎么会比readwrite差这么多,有人研究过吗?或是使用过sendfile的,有出现这样的情况吗?

论坛徽章:
15
射手座
日期:2014-02-26 13:45:082015年迎新春徽章
日期:2015-03-04 09:54:452015年辞旧岁徽章
日期:2015-03-03 16:54:15羊年新春福章
日期:2015-02-26 08:47:552015年亚洲杯之卡塔尔
日期:2015-02-03 08:33:45射手座
日期:2014-12-31 08:36:51水瓶座
日期:2014-06-04 08:33:52天蝎座
日期:2014-05-14 14:30:41天秤座
日期:2014-04-21 08:37:08处女座
日期:2014-04-18 16:57:05戌狗
日期:2014-04-04 12:21:33技术图书徽章
日期:2014-03-25 09:00:29
2 [报告]
发表于 2013-12-16 08:56 |只看该作者
newbieforever 发表于 2013-12-14 11:37
最近写了个测试程序,通过网络发送4G的文件到目标,分别用两种方式sandfile 和read 到本地BUFFER write ...

个人觉得,lo接口测试结果应该能说明问题,实际网口的性能差距可能不在sendfile上,可以检查下网络配置是否相同、oprofile采样看下热点、或者在相关流程中打点统计下时间消耗点。

论坛徽章:
0
3 [报告]
发表于 2013-12-16 11:18 |只看该作者
用netperf在40gb上跑了一下,write()的性能是7G,而sendfile可以到大24G。看起来有bug

论坛徽章:
6
金牛座
日期:2013-10-08 10:19:10技术图书徽章
日期:2013-10-14 16:24:09CU十二周年纪念徽章
日期:2013-10-24 15:41:34狮子座
日期:2013-11-24 19:26:19未羊
日期:2014-01-23 15:50:002015年亚洲杯之阿联酋
日期:2015-05-09 14:36:15
4 [报告]
发表于 2013-12-17 08:44 |只看该作者
回复 1# newbieforever
建议在物理机上测试,排除KVM的影响。

   
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP