mysql底层实现(五)---减少I/O的预读原理

减少I/O的预读原理

由于存储介质的特性,磁盘本身比驻村要慢得多,再加上机械运动所耗费的时间,磁盘的存取速度往往是主存的百分之一,所以为了提高效率,尽量的剑豪磁盘的I/O.;但是一般情况下磁盘都会预读,,一般是从一个位置开始,读取之后的一定长度的数据放入内存。这样做的理论依据是计算机科学中著名的局部性原理:

         当一个数据被用到时,其附近的数据一般来说也会被马上使用。

         程序运行期间所需要的数据通常比较集中。

         由于磁盘顺序读取的效率很高(不需要寻道时间,只需要很少的旋转时间),因此对于具有局部性的程序来说,预读可以提高 I/O 效率。

预读的长度一般是页的整数倍,页是计算机管理存储的逻辑块,硬件及操作系统往往会将主存和磁盘存储分割为连续的,大小相等的快。,每个存储块称之为页,在很多os中,也得大小一般是4K,主存和磁盘以页为单位交换数据的,当程序要读取的数据不存在主存中时,就会触发缺页异常。这时系统 会向磁盘发出读盘信息,磁盘会找到数据的其实位置,连续读取一页或者几页的数据存储在内存中异常返回,程序继续执行。

你可能感兴趣的:(MySql)