免费注册 查看新帖 |

Chinaunix

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

一个关于随机读写与顺序读写的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-08-26 23:24 |只看该作者 |倒序浏览
一个关于随机读写与顺序读写的问题

1.随机读是不是比顺序读速度快?
2.随机写是不是比顺序写慢?
3.存储阵列的随机读写是不是比顺序读写性能差
4.为什么?

THANKS!

论坛徽章:
0
2 [报告]
发表于 2009-08-27 01:20 |只看该作者
1. 随机读肯定比顺序读要慢,因为顺序读有预读到Cache中的动作,增大了Cache的命中率
2. 应该说,如果Cache足够大,随机写和顺序写都是一样快,都是写到Cache算完成(裸设备除外);如果Cache不够大,则要看Raid的划分,和随机写与顺序写没有必然的关系
3. 第三个问题的答案来源于1 和 2 问题的回答
4. 每个都说明了原因。

论坛徽章:
2
2015年迎新春徽章
日期:2015-03-04 09:49:45IT运维版块每日发帖之星
日期:2016-07-29 06:20:00
3 [报告]
发表于 2009-08-27 08:41 |只看该作者
关于第二点,不能绝对来说。理论上是可以这么说,但是实际测试中,即便cache足够大,随即写依然是慢于连续写,其中缘由很可能在于cache的算法,随即写要比连续写耗费更多的算法流程,其中buffer,queue,pool等要素,控制器在一定程度上安排好之后才会返回ack给主机,这样致使随即写还是比连续写要慢。欢迎继续针对这个问题讨论。

论坛徽章:
0
4 [报告]
发表于 2009-08-30 19:40 |只看该作者
硬盘与磁带相比,硬盘读写速度比磁带快,原因就是硬盘是随机读写,而磁带是顺序读写,这怎么解释?

论坛徽章:
0
5 [报告]
发表于 2009-08-30 22:12 |只看该作者
原帖由 beyondfool 于 2009-8-30 19:40 发表
硬盘与磁带相比,硬盘读写速度比磁带快,原因就是硬盘是随机读写,而磁带是顺序读写,这怎么解释?


单个硬盘不一定比单个磁带的写速度快,读速度硬盘肯定比磁带快的多

前面的比较随机和顺序都是比较在硬盘这种索引和扇区+cache的机制下,和磁带这种机械的查找物理位置的方式没有可比性~

论坛徽章:
0
6 [报告]
发表于 2009-08-30 22:16 |只看该作者
原帖由 冬瓜头 于 2009-8-27 08:41 发表
关于第二点,不能绝对来说。理论上是可以这么说,但是实际测试中,即便cache足够大,随即写依然是慢于连续写,其中缘由很可能在于cache的算法,随即写要比连续写耗费更多的算法流程,其中buffer,queue,pool等 ...


但是写入就写到cache之后就返回给server成功了,所以2楼老大说的cache足够大的情况下,应该是成立的吧,实际上不行是因为cache占用100%后会计算一下增加命中率,还有你说的那些来释放cache,但是“假设cache足够大”情况下cache根本不需要释放,慢慢往硬盘写,反正cache永远不满

论坛徽章:
2
2015年迎新春徽章
日期:2015-03-04 09:49:45IT运维版块每日发帖之星
日期:2016-07-29 06:20:00
7 [报告]
发表于 2009-08-31 08:55 |只看该作者
数据并不是扔到cache随便哪地方就完事ack的,需要经过一定的路径到特定的buffer中才能返回ack,如果真的从driver层拿过来就ack,那倒是没区别了。不过这个也得看产品设计,我们只从实际结果来判断,实际给出的结果不可否认。

论坛徽章:
0
8 [报告]
发表于 2009-08-31 09:07 |只看该作者
原帖由 冬瓜头 于 2009-8-31 08:55 发表
数据并不是扔到cache随便哪地方就完事ack的,需要经过一定的路径到特定的buffer中才能返回ack,如果真的从driver层拿过来就ack,那倒是没区别了。不过这个也得看产品设计,我们只从实际结果来判断,实际给出的结 ...


是,本来那个假定也不成立,cache不管多大,为了提高命中率总是很满的

论坛徽章:
0
9 [报告]
发表于 2009-09-03 07:12 |只看该作者
磁盘读速度比磁带快,是不是就是由于磁盘是随机读,磁带是顺序读?

论坛徽章:
2
2015年迎新春徽章
日期:2015-03-04 09:49:45IT运维版块每日发帖之星
日期:2016-07-29 06:20:00
10 [报告]
发表于 2009-09-03 08:34 |只看该作者
ls概念有点混乱。我估计你说的磁盘时随机读的意思是说磁盘可以random acess,磁带不能做到和磁盘一样,的确。但是这不是磁盘比磁带快的理由。磁盘每分成千上万转,白忙活了?
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP