忘记密码   免费注册 查看新帖 | 论坛精华区

ChinaUnix.net

  平台 论坛 博客 认证专区 大话IT HPC论坛 徽章 文库 沙龙 自测 下载 频道自动化运维 虚拟化 储存备份 C/C++ PHP MySQL 嵌入式 Linux系统
最近访问板块 发新帖
查看: 983 | 回复: 0

[网络] 请教sendfile和epoll结合起来使用的效率问题 [复制链接]

论坛徽章:
0
发表于 2017-07-20 15:38 |显示全部楼层
本帖最后由 dmrfan 于 2017-07-27 08:40 编辑

背景:
使用sendfile和epoll将本地文件发送到网络上:通过epoll获知socket可写了,然后调用sendfile开始读本地文件发送数据到网络上。

还不太清楚具体的触发条件&原因,观察到的现象是:
sendfile发送一点点数据出去之后(可能只有几KB甚至更小)就被epoll通知可以再发送了,于是sendfile开始读磁盘写socket,
导致每次sendfile读本地磁盘的IO都非常小(每次调用sendfile时,预期一次发送的大小是百KB,实际是KB级别)。

看起来是socket的发送buffer空出来一点点时,epoll就开始通知“可写”了?
希望epoll通知sendfile可以写socket时,socket的buffer大一些,这样sendfile每次读磁盘可以多读一点数据,提高磁盘吞吐。

想请教下,各位有遇到过类似问题吗,没找到是不是有什么参数可调,能否提供一点解决思路呢?谢谢。

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

本版积分规则

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号 北京市公安局海淀分局网监中心备案编号:11010802020122
广播电视节目制作经营许可证(京) 字第1234号 中国互联网协会会员  联系我们:
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP