缓冲池
缓冲池是主内存中的一个区域,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]