Innodb缓冲池

缓冲池是主内存中的一个区域,用于在 InnoDB访问时缓存表和索引数据。缓冲池允许直接从内存访问经常使用的数据,从而加快处理速度。在专用服务器上,多达 80% 的物理内存通常分配给缓冲池

为了提高大量读取操作的效率,缓冲池被划分为可能包含多行的页面。为了缓存管理的效率,缓冲池被实现为页面的链表;很少使用的数据使用最近最少使用 (LRU) 算法的变体从缓存中老化。

了解如何利用缓冲池将经常访问的数据保存在内存中是 MySQL 调优的一个重要方面。

缓冲池 LRU 算法

缓冲池使用 **LRU 算法的变体**作为列表进行管理。当需要空间将新页面添加到缓冲池时,最近最少使用的页面会被逐出,并将新页面添加到列表中间。此中点插入策略将列表视为两个子列表:

在头部,最近访问的新(“年轻”)页面 的子列表

在尾部,最近访问过的旧页面的子列表

在这里插入图片描述
该算法将经常使用的页面保留在新的子列表中。旧的子列表包含不太常用的页面;这些页面是驱逐的候选页面。

默认情况下,算法操作如下:

缓冲池的 3/8 专用于old sublist。

列表的中点是新子列表尾部与旧子列表头部相交的边界。

当InnoDB将页面读入缓冲池时,它最初将它插入到中点(old sublist的头部)因为它是用户有意的操作(例如 SQL 查询)所必需的,或者是由 自动执行的预读操作的一部分 InnoDB。

访问旧子列表中的页面使其 “年轻”,将其移动到新子列表的头部。如果页面是因为用户启动的操作需要它而被读取,则第一次访问会立即发生,并且页面会变年轻。如果页面是由于预读操作而读取的,则第一次访问不会立即发生,并且在页面被逐出之前可能根本不会发生。

随着数据库的运行,缓冲池中未被访问的页面会通过向列表尾部移动来“老化”。新旧子列表中的页面随着其他页面的更新而老化。旧子列表中的页面也会随着页面插入中点而老化。最终,一个未使用的页面到达旧子列表的尾部并被驱逐。

默认情况下,查询读取的页面会立即移动到新的子列表中,这意味着它们在缓冲池中停留的时间更长。例如,为mysqldump操作或SELECT没有WHERE子句的 语句 执行的表扫描可以将大量数据带入缓冲池并驱逐等量的旧数据,即使新数据不再使用。类似地,由预读后台线程加载且仅访问一次的页面被移动到新列表的头部。这些情况会将经常使用的页面推送到旧的子列表,在那里它们会被逐出。有关优化此行为的信息,请参阅 第 14.8.3.3 节,“使缓冲池扫描具有抵抗性”和 第 14.8.3.4 节,“配置 InnoDB 缓冲池预取(预读)”。

参考

MySQL :: MySQL 5.7 Reference Manual :: 14.5.1 Buffer Pool
https://dev.mysql.com/doc/refman/5.7/en/innodb-buffer-pool.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值