mysql 刷脏的时机


当内存数据和磁盘数据不一致时,称为脏页,反之为干净页面。内存刷新到磁盘称为flush。flush有如下情形:
1. redo log 写满。会造成mysql不接受更新。
2. 内存不足。
3. 空闲时间。
4. Mysql关闭时。
flush是常态。如何控制脏页很重要。InnoDB有控制脏页的策略如下:
根据磁盘性能设置innodb_io_capacity参数。刷盘速度根据一个是脏页比例,一个是redo log写盘速度。参数innodb_max_dirty_pages_pct是脏页比例上限,默认值是75%。

 

InnoDB 会在后台刷脏页,而刷脏页的过程是要将内存页写入磁盘。所以,无论是你的查询语句在需要内存的时候可能要求淘汰一个脏页,还是由于刷脏页的逻辑会占用 IO 资源并可能影响到了你的更新语句,都可能是造成你从业务端感知到 MySQL“抖”了一下的原因。

要尽量避免这种情况,你就要合理地设置 innodb_io_capacity 的值,并且平时要多关注脏页比例,不要让它经常接近 75%

其中,脏页比例是通过 Innodb_buffer_pool_pages_dirty/Innodb_buffer_pool_pages_total 得到的

posted on 2022-08-03 10:49  JennyYu  阅读(538)  评论(0编辑  收藏  举报