MySQL8中文手册-buffer pool使用说明

15.5.1 Buffer Poolbuffer pool是一块用于InnoDB引擎在请求数据时缓存表和索引数据的内存区域。buffer pool中允许直接从内存中读取经常使用的数据,这样可以提升数据访问速度。在专用的数据库服务器上,buffer pool经常可以使用多达80%的物理内存。为了提升大数据量读取操作的效率,buffer pool缓存的单位是数据页,一个数据页可以保存多行数据。为了提升缓存管理效率,buffer pool用链表来实现,最少被使用数据页会通过LRU算法被换出缓存。理解并最大限
摘要由CSDN通过智能技术生成
写在前面

网上充斥着各种MySQL的学习资料,有所谓的小白学习笔记也有大牛的分享文章,有免费的也有收费的,文章的质量也是鱼龙混杂,经常看到文章与文章之间相互矛盾,甚至文章前后矛盾。
至于为什么要翻译官方文档,还要源于上次学习极客时间的付费文章,其中一篇对change buffer的说明,文章中描述change buffer是用于更新数据缓存,后面又对change buffer和redo log的关系进行了说明,然而评论中有各种观点,有些说change buffer只针对索引数据进行缓存,文章前后翻了好几遍,始终有个疑问,change buffer到底缓存的是什么内容?在度娘上查找,也是各种说法都有。
为了彻底弄明白这个问题,我去查找了MySQL8的官方英文文档,发现文档中描述非常清楚,change buffer的缓存对象是非唯一二级索引,缓存的是二级索引的变更操作(insert、update、delete),前面的一切疑问都明白了。
经过这件事后,我开始翻译MySQL8的使用手册,这才是最权威的最值得参考的资料,翻译过程参考了百度和谷歌翻译,但大部分还是人工翻译,因此难免有些理解偏差,请大家及时指正。

更多内容请点击MySQL8中文手册

15.5.1 Buffer Pool

buffer pool是一块用于InnoDB引擎在请求数据时缓存表和索引数据的内存区域。buffer pool中允许直接从内存中读取经常使用的数据,这样可以提升数据访问速度。在专用的数据库服务器上,buffer pool经常可以使用多达80%的物理内存。

为了提升大数据量读取操作的效率,buffer pool缓存的单位是数据页,一个数据页可以保存多行数据。为了提升缓存管理效率,buffer pool用链表来实现,最少被使用数据页会通过LRU算法被换出缓存。

理解并最大限度的使用buffer pool来缓存最常使用的数据,对MySQL的调优来说非常重要。

buffer pool 的LRU算法

buffer pool使用LRU的一种变种算法进行管理。当需要增加一个新的数据页的时候,最近最少被使用的数据页被换出内存,新增加的数据源添加到列表的中间位置。往列表中间位置插入新数据页的侧脸,把列表分为两个子列表。

  • 列表的前面,是经常被访问的年轻的数据页
  • 列表的后面,是不经常被访问的老年数据页
    Figure 15.2 Buffer Pool List
    在这里插入图片描述

这种LRU算法把经常使用的数据保持在年轻代列表里&#

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值