900字范文,内容丰富有趣,生活中的好帮手!
900字范文 > MySQL数据库InnoDB存储引擎 Buffer Pool Flush List详解

MySQL数据库InnoDB存储引擎 Buffer Pool Flush List详解

时间:2024-03-17 19:10:43

相关推荐

MySQL数据库InnoDB存储引擎 Buffer Pool Flush List详解

数据库|mysql教程

InnoDB,MySQL数据库InnoDB存储引擎 Buff

数据库-mysql教程

时时彩源码搭建教程,vscode编辑器主题,ubuntu生存游戏,tomcat有那些目录,puppeteer爬虫写法,php 数据库 购物车,从化区企业seo优化包括什么,最全彩种网站,ios8模板lzw

dirty page是在什么时候进入flush list的呢?看过我以前文档的同学,一定知道InnoDB存储引擎有一个所谓的mini-transaction,页面

小区物业ui源码,ubuntu网关怎么写,爬虫天猫违法,简述php,seo输出负数lzw

shopnc免费源码,vscode怎么下载代码,ubuntu 终端会话,前端页面tomcat部署,爬虫怕冷,php转,中山教育seo优化技巧,网站源码之家工具,手机端导航网站模板下载lzw

Buffer Pool Flush List

add page to flush list

buffer pool中的page,有三种状态:

free: 当前page未被使用

clean: 当前page被使用,对应于数据文件中的一个页面,但是页面未被修改

dirty: 当前page被使用,对应于数据文件中的一个页面,同时页面被修改

free类型的page,一定位于buf pool的free链表中。

clean,dirty两种类型的page,一定位于buf pool的LRU链表中。

与此同时,dirty page还位于buf pool的flush链表中。flush list中的dirty page,按照page的oldest_modificattion时间排序,oldest_modification越大,说明page修改的时间越晚,就排在flush 链表的头部;oldest_modification越小,说明page修改的时间越早,就排在flush链表的尾部。当InnoDB进行flush list的flush操作时,从flush list链表的尾部开始,写出足够数量的dirty pages,推进Checkpoint点,保证系统的恢复时间。

那么,dirty page是在什么时候进入flush list的呢?看过我以前文档的同学,,一定知道InnoDB存储引擎有一个所谓的mini-transaction,页面访问/修改都被封装为一个mini-transaction,当mini-transactin提交的时候,也就是该mini-transaction修改的页面进入flsuh list的时候。

mtr_commit -> mtr_memo_note_modification();

// 若当前page已经是dirty page,不是第一次修改,那么说明当前page已经在

// flush list之中,因此不需要再次加入flush list

if (block->page.oldest_modification)

ut_ad(block->page.oldest_modification <= mtr_start_lsn);

else

// 若当前page是第一次修改,oldest_modification = 0,则将page加入flush list

buf_flush_insert_into_flush_list();

buf_flush_list_mutex_enter(buf_pool);

remove page from flush list

有两种操作,可以将dirty page从flush list中移除。一是LRU list flush;二是Flush list flush。其中,LRU list flush已经在前面的章节中分析。

而Flush list flush,也就是我们通常所说的InnoDB fuzzy Checkpoint,可以参考我以前的一个文档:MySQL InnoDB Insert Buffer Checkpoint AIO实现分析 。

更多详情见请继续阅读下一页的精彩内容:

推荐阅读:

InnoDB存储引擎的启动、关闭与恢复

MySQL InnoDB独立表空间的配置

MySQL Server 层和 InnoDB 引擎层 体系结构图

InnoDB 死锁案例解析

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。