• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

从数据库层面理解:随机 I/O & 顺序 I/O

mysql 搞代码 4年前 (2022-01-09) 24次浏览 已收录 0个评论

在 谈这俩概念前、先来说说 大I/O vs. 小I/O 通常、我们把 =16KB 的I/O认为是小I/O、而 =32KB 的I/O认为是大I/O 了解I/O的大

谈这俩概念前、先来说说 大I/O vs. 小I/O
通常、我们把 <=16KB 的I/O认为是小I/O、而 >=32KB 的I/O认为是大I/O
了解I/O的大小、影响到后期对缓存、RAID类型、LUN的一些属性的调优

当前大多数数据库使用的都是传统的机械磁盘
因此、整个系统设计要尽可能顺序I/O
避免昂贵的寻道时间和旋转延迟的开销
随机小I/O消耗比顺序大I/O更多的处理资源
随机小I/O更在意系统处理I/O的数量、即IOPS、比如、OLTP
而顺序大I/O则更在意带宽、即MB/s、比如、OLAP
因此、如果系统承载了多种不同的应本文来源gaodaimacom搞#^代%!码&网(
必须了解它们各自的需求、是对IOPS有要求、还是对带宽有要求

传统机械磁盘最大的问题在于读写磁头

读写磁头的存在可以让磁盘既能顺序I/O、也可随机I/O

但是、随机I/O需要花费昂贵的磁头旋转和定位来查找

因此、顺序IO访问的速度远远快于随机IO

数据库的很多设计也都是尽量充分利用顺序IO、比如Oracle REDO LOG写便是顺序IO


如果、数据库服务器同时使用顺序和随机I/O、随机I/O从缓存中受益最多
原因有 3 :
① 顺序I/O一般只需扫描一次数据、所以、缓存对它用处不大
② 顺序I/O比随机I/O快
③ 随机I/O通常只要查找特定的行、但I/O的粒度是页级的、其中大部分是浪费的
而、顺序I/O所读取的数据、通常发生在想要的数据块上的所有行
更加符合成本效益
所以、缓存随机I/O可以节省更多的workload

传统的数据库架构对随机IO几乎没有还手之力、随机IO几乎令所有DBA谈虎色变
而聪明如MySQL InnoDB 则利用事务日志把随机I/O转成顺序I/O
窃以为、如果能负担得起、增加内存是解决随机I/O最好的办法


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:从数据库层面理解:随机 I/O &amp; 顺序 I/O

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址