免费注册 查看新帖 |

Chinaunix

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

如何提高读文件效率? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-08-11 15:38 |只看该作者 |倒序浏览
应用是把一些文件(有大有小,最大可达1G以上)通过UDP包发出去
我试过以下几种方法:
1.fread(假设1000B)后send(假设1000B)
2.fread(假设10000B)后send(假设1000B)
3.一个线程fread,一个线程send
4.内存映射

结果:
1和2速度差不多,
3要快一些,但也快不了多少,4忘了,但好像在处理大文件时比较慢

实现上1,2,4相对简单,3要麻烦些

请问还有什么比较好的方法,谢谢!

论坛徽章:
0
2 [报告]
发表于 2008-08-11 16:54 |只看该作者

回复 #1 mikenoodle 的帖子

无疑采用多线程较好。但是你仍需要先确定程序的瓶颈在哪里。如果是读文件,可考虑内存映射;如果是发送网络包,可考虑压缩网络数据。。。

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
3 [报告]
发表于 2008-08-11 19:40 |只看该作者
原帖由 mikenoodle 于 2008-8-11 15:38 发表
应用是把一些文件(有大有小,最大可达1G以上)通过UDP包发出去
我试过以下几种方法:
1.fread(假设1000B)后send(假设1000B)
2.fread(假设10000B)后send(假设1000B)

读取的单位最好是按照 page size 来,例如以 4K 为单位。

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
4 [报告]
发表于 2008-08-11 19:41 |只看该作者
原帖由 web_surf 于 2008-8-11 16:54 发表
但是你仍需要先确定程序的瓶颈在哪里。

嗯,过早考虑优化不是什么好主意。

论坛徽章:
0
5 [报告]
发表于 2008-08-12 00:21 |只看该作者

回复 #3 MMMIX 的帖子

好像是有这么一个说法,不过fread不是带缓冲的么,它向下读时就按最优的大小读了吧
另外,由于网络协议规定,发包时大小是1000,那么按4k来读,就变成了第2种了方法了,经试验效率差不多

论坛徽章:
0
6 [报告]
发表于 2008-08-12 00:26 |只看该作者

回复 #4 MMMIX 的帖子

程序无非就是循环读文件,发送,在发送时直接send的(两次,发双包),10M的网卡,2410cpu,2.6内核,发送速度大约在500-510kB/s左右,估计瓶颈就是在读文件处

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
7 [报告]
发表于 2008-08-12 00:55 |只看该作者
原帖由 mikenoodle 于 2008-8-12 00:26 发表
程序无非就是循环读文件,发送,在发送时直接send的(两次,发双包),10M的网卡,2410cpu,2.6内核,发送速度大约在500-510kB/s左右,估计瓶颈就是在读文件处

做下 profiling 嘛,估计啥?

论坛徽章:
0
8 [报告]
发表于 2008-08-12 07:19 |只看该作者
说远点,LZ既然目的是传文件,为啥不变通一下?
比如,如果支持FTP的话,用FTP传送,或者scp,rsync等,看看这些现成工具的效率如何
一般遇到这种很典型的问题,俺还是习惯借助系统自带工具
这几天在研究axel,等有眉目了可以讨论下能否借鉴Axel的方法

论坛徽章:
0
9 [报告]
发表于 2008-08-12 11:05 |只看该作者

回复 #7 MMMIX 的帖子

偶小菜,呵呵,谢谢MMMIX大哥指点,又多学了一样东西,这就去试试

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
10 [报告]
发表于 2008-08-12 20:06 |只看该作者
原帖由 duanjigang 于 2008-8-12 07:19 发表
说远点,LZ既然目的是传文件,为啥不变通一下?
比如,如果支持FTP的话,用FTP传送,或者scp,rsync等,看看这些现成工具的效率如何
一般遇到这种很典型的问题,俺还是习惯借助系统自带工具

没错,是应该先找现成工具。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP