您的位置:首页 > Web前端

14.4.3.5 Configuring InnoDB Buffer Pool Flushing 配置InnoDB Buffer Pool 刷新:

2016-06-24 16:50 369 查看
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 每秒钟。

这种自适应的算法是可以处理突然的负载的改变

内部基准表明 算法不能保持吞吐量随着时间推移,但是也改善了吞吐量
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: