mysql 缓存体系_mysql8 参考手册--InnoDB存储引擎的内存体系结构-缓冲池

缓冲池

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

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

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

缓冲池LRU算法

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

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

在尾部,是一个旧页的子列表,这些旧页最近访问的次数较少

缓冲池配置

您可以配置缓冲池的各个方面以提高性能。

理想情况下,您可以将缓冲池的大小设置为尽可能大的值,为服务器上的其他进程留下足够的内存,以便在不进行过度分页的情况下运行。缓冲池越大,InnoDB就越像内存中的数据库,从磁盘读取一次数据,然后在随后的读取过程中从内存访问数据。

在具有足够内存的64位系统上,可以将缓冲池分成多个部分,以最小化并发操作之间的内存结构争用。

您可以将频繁访问的数据保存在内存中,而不必考虑将大量不常访问的数据带入缓冲池的操作所导致的活动突然激增。

您可以控制何时以及如何执行预读请求,以异步将页预取到缓冲池中,以预期不久将需要这些页。

您可以控制何时进行后台刷新,以及是否根据工作负载动态调整刷新速率。

您可以配置InnoDB如何保留当前缓冲池状态,以避免服务器重启后长时间的预热。

使用InnoDB标准监视器监视缓冲池

InnoDB标准监视器输出(可以使用SHOW ENGINE InnoDB STATUS访问)提供有关缓冲池操作的度量。缓冲池度量位于InnoDB Standard Monitor输出的缓冲池和内存部分,类似于以下内容:

----------------------

BUFFER POOL AND MEMORY

----------------------

Total large memory allocated 2198863872

Dictionary memory allocated 776332

Buffer pool size 131072

Free buffers 124908

Database pages 5720

Old database pages 2071

Modified db pages 910

Pending reads 0

Pending writes: LRU 0, flush list 0, single page 0

Pages made young 4, not young 0

0.10 youngs/s, 0.00 non-youngs/s

Pages read 197, created 5523, written 5060

0.00 reads/s, 190.89 creates/s, 244.94 writes/s

Buffer pool hit rate 1000 / 1000, young-making rate 0 / 1000 not

0 / 1000

Pages read ahead 0.00/s, evicted without access 0.00/s, Random read

ahead 0.00/s

LRU len: 5720, unzip_LRU len: 0

I/O sum[0]:cur[0], unzip sum[0]:cur[0]

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值