前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Mysql在哪些场景会flush脏页?

Mysql在哪些场景会flush脏页?

作者头像
用户9919783
发布2022-07-29 13:52:18
5850
发布2022-07-29 13:52:18
举报
文章被收录于专栏:后端从入门到精通

我们在日常使用sql中,查询数据库反映的时间过长,这时候可能是flush脏页导致的,而脏页会什么时候触发呢?

当查询的数量太多,每次全量查询都会淘汰掉脏页从而触发磁盘的I/O操作户导致查询时间过长。

当innoDB的redo log满了后,这时候会占用内存优先刷新redo日志,执行flush吧数据刷到磁盘,腾出redo log空间。

系统内存不足时候,需要淘汰脏页给新的页使用。

当mysql系统认为空闲的时候,会刷新脏页到磁盘。

当mysql服务器正常关闭,会刷新脏页到磁盘。

脏页和干净页都是在内存里的,当磁盘上的数据与buffer pool里的数据不一致,这时候就是脏页。当内存里的数据写到磁盘后,内存和磁盘里的内容数据保持一致,则称为干净页。

Buffer pool的作用是干嘛的,是为了减少磁盘的I/O,innoDB不可能每次存入一条数据都对磁盘访问一次,因为磁盘的i/o相对于内存是非常慢的,所以在mysql服务器启动的时候,会申请个内存作用于buffer pool。(innoDB-buffer-pool-size)

因为有脏页和干净页的存在,所以有了free 链表 和 flush链表,以及lru链表,每次有新数据查询,总不能每次查找干净页,与是干净页同意放在free链表,修改数据的脏页统一放在flush链表。而每次不可能吧所有页都刷新到磁盘,为了减少磁盘刷新的频率,所以选一部分淘汰,这时候lru链表就出现了,这里面有热数据和冷数据,比例是3:7,因为innoDB查询会自动预读,来提高查询效率,这时候为了解决预读问题,第一次查询的数据会放入冷数据,如果在一个临界点,超过innoDB_block_time设置的时间,再查一次,则会放入热数据,冷数据的地方就会慢慢淘汰。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2021-11-01,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 后端从入门到精通 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档