磁盘预读与innodb的页大小关系

参考文章:mysql的B+树如何存储主键和数据,磁盘io和innodb页大小的一些问题

磁盘预读以及如何保证每次都能拿到innodb的一页也就是16kb的数据
(1)磁盘预读
预读其实就是利用了局部性原理,具体过程是:对于每个文件的第一个读请求,系统读入所请求的页面并读入紧随其后的少数几个页面(通常是三个页面),这时的预读称为同步预读。

  我们知道对大部分操作系统来说,磁盘的一页数据是4kb,那么算上预读的3页:

4kb(磁盘一页的大小) + 12kb(预读三个页面) = 16kb
1
(2)关于每次读取16kb数据
这个16kb是innodb默认的页大小,为什么会有这个概念呢,因为当涉及到数据库读写的时候,规定数据库每次读写都是以16k为单位的,一次最少从磁盘中读取16KB的内容到内存中,一次最少把内存中的16KB内容刷新到磁盘中。

(3)磁盘io固定是每次读取4kb的吗
答案明显不是的,io读取是可大可小的,具体看指令的内容,并不是每次只能读取固定的1页。比如上面解释一次io概念的时候,我们提到了指令,这个指令是类似于给出两个参数,第一个参数是要开始读取的扇区地址,第二个参数是要读取多少扇区。

  所以每次io的大小是根据指令来决定的,并不是每次只能读取磁盘的一页数据,也就是4kb。

(4)网友的问题
主要是明确磁盘中的一页数据(4kb)和数据库innodb规定的一页数据(16kb),这两个的概念是不一样的。磁盘io的大小也是根据指令来规定的。对应数据库读写来说,会按照数据库的配置,每次最少读写一页数据,也就是16kb。

4、设置页大小为64kb,是否一次io就拿不到对应的数据了,需要多次io?
其实这个问题上面已经给出了答案。设置innodb页大小为64kb之后,我们每次数据库的读写就必须操作64kb的数据了而已,和io次数没什么关系的。

  • 4
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值