- 1、本文档共11页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
图文13从磁盘读取数据页到BufferPool的时候,free链表有什么用?手机观看
307人次阅读2020-02-0709:03:31
详情评论
从磁盘读取数据页到BufferPool的时候,free链表有什么用?
如何提问:每篇文章都有评论区,大家可以尽情留言提问,我会逐一答疑
如何加群:购买狸猫技术窝专栏的小伙伴都可以加入狸猫技术交流群,一个非常纯粹的技术交流的地方
具体加群方式,请参见目录菜单下的文档:《MySQL专栏付费用户如何加群》(购买后可见)
1、数据库启动的时候,是如何初始化BufferPool的?
现在我们已经搞明白一件事儿了,那就是数据库的BufferPool到底长成个什么样,大家想必都是理解了
其实说白了,里面就是会包含很多个缓存页,同时每个缓存页还有一个描述数据,也可以叫做是控制数据,但是我个人是比较
倾向于叫做描述数据,或者缓存页的元数据,都是可以的。
那么在数据库启动的时候,他是如何初始化BufferPool的呢?
其实这个也很简单,数据库只要一启动,就会按照你设置的BufferPool大小,稍微再加大一点,去找操作系统申请一块内存区
域,作为BufferPool的内存区域。
然后当内存区域申请完毕之后,数据库就会按照默认的缓存页的16KB的大小以及对应的800个字节左右的描述数据的大小,在
BufferPool中划分出来一个一个的缓存页和一个一个的他们对应的描述数据。
然后当数据库把BufferPool划分完毕之后,看起来就是之前我们看到的那张图了,如下图所示。
只不过这个时候,BufferPool中的一个一个的缓存页都是空的,里面什么都没有,要等数据库运行起来之后,当我们要对数据
执行增删改查的操作的时候,才会把数据对应的页从磁盘文件里读取出来,放入BufferPool中的缓存页中。
2、我们怎么知道哪些缓存页是空闲的呢?
接着我们来看下一个问题,当你的数据库运行起来之后,你肯定会不停的执行增删改查的操作,此时就需要不停的从磁盘上读
取一个一个的数据页放入BufferPool中的对应的缓存页里去,把数据缓存起来,那么以后就可以对这个数据在内存里执行增删
改查了。
但是此时在从磁盘上读取数据页放入BufferPool中的缓存页的时候,必然涉及到一个问题,那就是哪些缓存页是空闲的?
因为默认情况下磁盘上的数据页和缓存页是一一对应起来的,都是16KB,一个数据页对应一个缓存页。
所以我们必须要知道BufferPool中哪些缓存页是空闲的状态。
所以数据库会为BufferPool设计一个free链表,他是一个双向链表数据结构,这个free链表里,每个节点就是一个空闲的缓存
页的描述数据块的地址,也就是说,只要你一个缓存页是空闲的,那么他的描述数据块就会被放入这个free链表中。
刚开始数据库启动的时候,可能所有的缓存页都是空闲的,因为此时可能是一个空的数据库,一条数据都没有,所以此时所有
缓存页的描述数据块,都会被放入这个free链表中
我们看下图所示
大家可以看到上面出现了一个free链表,这个free链表里面就是各个缓存页的描述数据块,只要缓存页是空闲的,那么他们对
应的描述数据块就会加入到这个free链表中,每个节点都会双向链接自己的前后节点,组成一个双向链表。
除此之外,这个free链表有一个基础节点,他会引用链表的头节点和尾节点,里面还存储了链表中有多少个描述数据块的节
点,也就是有多少个空闲的缓存页。
3、free链表占用多少内存空间?
可能有的人会以为这个描述数据块,在BufferPool里有一份,在free链表里也有一份,好像在内存里有两个一模一样的描述数
据块,是么?
其实这么想就大错特错了。
这里要给大家讲明白一点,这个free链表,他本身其实就是由BufferPool里的描述数据块组成的,你可以认为是每个描述数据
块里都有两个指针,一个是free_pre,一个是free_next,分别指向自己的上一个free链表的节点,以及下一个free链表的节
点。
通过BufferPool中的描述数据块的free_pre和free_next两个指针,就可以把所有的描述数据块串成一个free链表,大
您可能关注的文档
- 从0开始带你成为MySQL实战高手11 从数据的增删改开始讲起,回顾一下Buffer Pool在数据库里的地位.pdf
- 从0开始带你成为MySQL实战高手12 Buffer Pool这个内存数据结构到底长个什么样子.pdf
- 从0开始带你成为MySQL实战高手14 当我们更新Buffer Pool中的数据时,flush链表有什么用.pdf
- 从0开始带你成为MySQL实战高手15 当Buffer Pool中的缓存页不够的时候,如何基于LRU算法淘汰部分缓存.pdf
- 从0开始带你成为MySQL实战高手16 简单的LRU链表在Buffer Pool实际运行中,可能导致哪些问题.pdf
- 从0开始带你成为MySQL实战高手17 MySQL是如何基于冷热数据分离的方案,来优化LRU算法的.pdf
- 从0开始带你成为MySQL实战高手18 基于冷热数据分离方案优化后的LRU链表,是如何解决之前的问题的.pdf
- 从0开始带你成为MySQL实战高手19 MySQL是如何将LRU链表的使用性能优化到极致的.pdf
- 从0开始带你成为MySQL实战高手20 对于LRU链表中尾部的缓存页,是如何淘汰他们刷入磁盘的.pdf
- 2025年家居收纳用品行业分析报告.docx
文档评论(0)