14.6.3.4 Configuring InnoDB Buffer Pool Prefetching (Read-Ahead) 配置InnoDB Buffer pool 预取

时间:2022-05-29 03:57:34
14.6.3.4 Configuring InnoDB Buffer Pool Prefetching (Read-Ahead) 配置InnoDB Buffer pool 预取

一个预读请求是一个I/O 请求异步预取多个pages到buffer pool.


预估那些Pages 马上会被需要。 请求把所有的Pages 到一个extent.

InnoDB 使用2种预读算法来改善I/O性能


线性的预读是一种技术是预测哪个page 可能马上被需要在buffer pool中被顺序访问的pages.

你控制什么时候InnoDB 执行一个预读操作通过调整 顺序page访问的数量 需要出发一个异步读请求,

使用配置参数innodb_read_ahead_threshold。

mysql> show variables like '%innodb_read_ahead_threshold%';
+-----------------------------+-------+
| Variable_name | Value |
+-----------------------------+-------+
| innodb_read_ahead_threshold | 56 |
+-----------------------------+-------+
1 row in set (0.00 sec)


在这个参数被增加前,InnoDB 只会计算是否执行一个异步预取请求对于整个接下来的extent 当他读取当前extent的最后的page


配置参数 innodb_read_ahead_threshold 控制 InnoDB 探测的灵敏度是检测顺序page访问的模式。


如果pages的读取数量是频繁的从一个extent 是大于或者等于 innodb_read_ahead_threshold

InnoDB 发起一个异步的预读操作来读取整个接下来的extent.


innodb_read_ahead_threshold 可以设置为任何值从0-64. 默认值是56


值越大,访问模式检查越严格。

比如,如果你设置值为48,InnoDB 触发一个线性预读请求只有当48个pages 在当前的extent 已经被顺序访问。


如果值是8,InnoDB 触发一个异步预读 即使 只有8个pages 在extent被顺序访问。


随机预读是一种技术预测页面可能被马上需要机遇已经在buffer pool里存在的pages,


不管 那些pages被读取的顺序。