14.4.3.5 Configuring InnoDB Buffer Pool Flushing 配置InnoDB Buffer Pool 刷新:
InnoDB执行某些任务在后台, 包括flush 脏数据(那些页已经被修改了但是没有会写到磁盘) 在Buffer pool
里。
InnoDB flush buffer pool pages 如果脏页的比例在buffer pool 已经大于或
innodb_max_dirty_pages_pct.者等于innodb_max_dirty_pages_pct.
mysql> show variables like '%innodb_max_dirty_pages_pct%';
+--------------------------------+-------+
| Variable_name | Value |
+--------------------------------+-------+
| innodb_max_dirty_pages_pct | 75 |
| innodb_max_dirty_pages_pct_lwm | 0 |
+--------------------------------+-------+
2 rows in set (0.00 sec)
InnoDB 使用一种算法来评估需要的刷新速率,基于redo log 生产的速度护额当前刷新的频率。
目的是消除性能通过确保buffer flush 活动保持与 buffer pool "clean" 需要
自动的调整 刷新的速度 可以帮助避免急速的下降在吞吐量上,当过多的buffer pool 刷新限制了
I/O可以容量对于普通的读和写活动
InnoDB 使用它的log files 以循环的方法,在重用日志文件的一部分,
InnoDB flushes 到磁盘 所有的dirty buffer pool pages,那些redo entries 是包含在log files 中的,
一个过程被称为一个锋利的检查点。
如果一个负载是密集写的,它产生了大量的redo 信息,所有写入到log file.
如果所有可能的空间在log files 是被占用,一个犀利的检查点发生,导致吞吐量暂时减少,
这个情况肯呢过发生尽管innodb_max_dirty_pages_pct 没有达到。
InnoDB 使用一个基于启发式算法来避免这样的情况,通过测量dirty pages 的数量在buffer pool
和redo 生产的速率。
基于这些数字,InnoDB 决定有多少dirty pages flush 从buffer pool 每秒钟。
这种自适应的算法是可以处理突然的负载的改变
内部基准表明 算法不能保持吞吐量随着时间推移,但是也改善了吞吐量