关于 LRU_List ,Free_List,Flush_List的介绍:
 
LRU算法:(Latest Recent Used)最近最少使用
     数据库的缓冲池通过LRU算法来进行管理。
     即,最频繁使用的页在LRU列表的前端,最少使用的页在LRU列表的尾端。当缓冲不能存放新读取到的页时,首先释放LRU列表尾端的页。
 
InnoDB存储引擎中,缓冲池中页默认大小16KB,也通过LRU列表对缓冲池进行管理,并对传统的LRU算法做了优化。在LRU列表中加入了midpoint位置。
     
 
midpoint位置设置:innodb_old_block_pct 默认:37 也就是3/8位置
midpoint之前的称为:new列表,之后的称为:old列表。
 
问题 1:为什么不将读取的页放入到LRU列表的首部?
      答:LRU列表,当不能存放新读取的页时,会释放尾部的页。若直接插入首部位置,某些SQL操作会使缓冲池中的页被刷新出去,尤其是读取大量的新页,直接插入首部,会使活跃的页逐渐被刷新出去。比如:索引或数据的全表扫描。这些页可能只在这次中用,但是活跃的页被刷新出去,下次读取该页,需要再次访问磁盘。
 
问题 2:解决类似全表扫描操作时,LRU列表中热点数据不被刷出
      答:设置参数:innodb_old_block_time:表示页读取到mid位置后需要等待多久才会被加入到LRU列表的热端。
          设置参数:innodb_old_block_pct :通过预估热点数据百分比。37-->20,降低mid位置,增加热点范围。
 
Free list:
 
LRU管理已经读取的页,数据库启动时,LRU列表是空的,没有页。此时的页都放在Free list。当需要从缓冲池中分页时,先查看Free list是否有空闲的页,若有,则从Free list中删除该页,放入到LRU列表。
若没有,则根据LRU算法,释放LRU列表尾端的页,将该内存分给新页。
 
page made young :当页从LRU列表的old部分加入到new部分时,此时的操作称为:page made young
page not made young:因为innodb_old_block_time设置,导致页没有从old部分移动到new部分的操作称为:page not made young。
 
如图:
mysql>SHOW ENGINE INNODB STATUS\G
 
---BUFFER POOL 3
Buffer pool size        204799     # *16KB
Buffer pool size, bytes 3355426816
Free buffers            1024
Database pages          193488
Old database pages      145096
Modified db pages       414
Pending reads 0
Pending writes: LRU 0, flush list 0, single page 0
Pages made young 12977471, not young 326415366
 
Database pages :表示LRU列表中页的个数
 
Database pages + Free buffers <Buffer pool size
 
缓冲池中的页 可能分配给:自适应哈希索引,lock信息,insert buffer等页,这些页不需要LRU算法运行维护,因此不在LRU列表中。
 
缓冲池的运行状态:
1.
SELECT POOL_ID,HIT_RATE,PAGES_MADE_YOUNG,PAGES_NOT_MADE_YOUNG FROM `information_schema`.`INNODB_BUFFER_POOL_STATS`;
 
mysql>SHOW ENGINE INNODB STATUS\G
Pending writes: LRU 0, flush list 0, single page 0
Pages made young 12977554, not young 326416098
0.00 youngs/s, 0.00 non-youngs/s
Pages read 3489114, created 521364, written 31146169
0.00 reads/s, 0.00 creates/s, 0.00 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: 193491, unzip_LRU len: 0
I/O sum[1]:cur[0], unzip sum[0]:cur[0]
 
2.通过INNODB_BUFFER_PAGE_LRU表查看LRU中每个页的状态
 
LRU中对于页的处理:
InnoDB存储引擎1.0.x版本开始支持压缩页的功能,即将16KB的页压缩成:1KB,2KB,4KB,8KB.
页的大小发生变化,LRU的管理页变。
非16KB的页,用unzip_LRU列表进行管理。
 
mysql>SHOW ENGINE INNODB STATUS\G
LRU len: 193491, unzip_LRU len: 0
I/O sum[1]:cur[0], unzip sum[0]:cur[0]
 
---LRU len:所有的页,包括压缩页。
---LRU len = unzip_LRU len + 非压缩页
 
表页的压缩比例不同,unzip_LRU是怎么从缓冲池中分配内存的?
     答:unzip_LRU也是有自己的分类的,根据1,2,4,8分类。
     unzip_LRU列表对不同压缩页大小的页进行分别管理。其次通过伙伴算法进行内存的分配:以4KB为例
1)检查4KB的unzip_LRU列表,是否有可用的空闲页
2)若有,直接使用
3)否则,检查8KB的unzip_LRU列表
4)若能得到空闲页,将页分成2个4KB页,存放到4KB的unzip_LRU列表中。
5)若不能得到,从LRU列表中申请16KB的页,将页分成1个8KB,2个4KB,分别放在对应的unzip_LRU中。
 
Flush list
在LRU列表中的页被修改后,称该页为脏页(dirty page),即缓冲池中的页和磁盘上的页数据不一致。这时会通过checkpoint机制将脏页刷新回磁盘,而Flush list中的页即为脏页列表。
注:脏页既存在于LRU列表,也存在于Flush列表中。
LRU:用来管理缓冲池中页的可用性
Flush:用来管理将页刷新回磁盘。
 
mysql>SHOW ENGINE INNODB STATUS\G
 
---BUFFER POOL 3
Buffer pool size        204799     # *16KB
Buffer pool size, bytes 3355426816
Free buffers            1024
Database pages          193488
Old database pages      145096
Modified db pages       414      #显示脏页的数量
 
 --ok

MySQL-LRU_List Free_List Flush_List的更多相关文章

  1. 关于MySQL checkpoint

    Ⅰ.Checkpoint 1.1 checkpoint的作用 缩短数据库的恢复时间 缓冲池不够用时,将脏页刷到磁盘 重做日志不可用时,刷新脏页 1.2 展开分析 page被缓存在bp中,page在bp ...

  2. MySQL redo lock 死锁问题排查 & 解决过程

    版权声明:本文由张青林原创文章,转载请注明出处: 文章原文链接:https://www.qcloud.com/community/article/181 来源:腾云阁 https://www.qclo ...

  3. MySQL · 性能优化· InnoDB buffer pool flush策略漫谈

    MySQL · 性能优化· InnoDB buffer pool flush策略漫谈 背景 我们知道InnoDB使用buffer pool来缓存从磁盘读取到内存的数据页.buffer pool通常由数 ...

  4. MySQL · 引擎特性 · InnoDB 事务子系统介绍

    http://mysql.taobao.org/monthly/2015/12/01/ 前言 在前面几期关于 InnoDB Redo 和 Undo 实现的铺垫后,本节我们从上层的角度来阐述 InnoD ...

  5. MySQL · 引擎特性 · InnoDB奔溃恢复

    前言 数据库系统与文件系统最大的区别在于数据库能保证操作的原子性,一个操作要么不做要么都做,即使在数据库宕机的情况下,也不会出现操作一半的情况,这个就需要数据库的日志和一套完善的奔溃恢复机制来保证.本 ...

  6. MySQL · 引擎特性 · InnoDB崩溃恢复

    前言 数据库系统与文件系统最大的区别在于数据库能保证操作的原子性,一个操作要么不做要么都做,即使在数据库宕机的情况下,也不会出现操作一半的情况,这个就需要数据库的日志和一套完善的崩溃恢复机制来保证.本 ...

  7. 【MySQL】InnoDB 内存管理机制 --- Buffer Pool

    InnoDB Buffer Pool 是一块连续的内存,用来存储访问过的数据页面 innodb_buffer_pool_size 参数用来定义 innodb 的 buffer pool 的大小 是 M ...

  8. mysql内存管理

    1 内存管理结构 mysql有自己的内存申请和释放机制 mysql层有mem_root innodb层有mem_heap,mem_pool,buf_pool 它们的结构图如下 2 mem_root m ...

  9. MySQL系列:innodb源代码分析之内存管理

    在innodb中实现了自己的内存池系统和内存堆分配系统,在innodb的内存管理系统中,大致分为三个部分:基础的内存块分配管理.内存伙伴分配器和内存堆分配器.innodb定义和实现内存池的主要目的是提 ...

随机推荐

  1. To Be a Dog Man

    作为一个多年的篮球爱好者,多年保持者对于足球的偏见. 也许不了解也是偏见開始的地方. 直到我最终看到了那个男人---梅西 梅西:一个犬人,一个病人 视频作者是阿根廷专栏作家Hernam Casciar ...

  2. ActiveMQ部署步骤和后台管理网站Service Unavailable问题解决笔记

    最近部署ActiveMQ的时候,发现有的服务器可以打开后台管理网址,有的服务器无法打开,Jetty报503 Service Unavailable. 搞了很久终于发现了问题,现将部署和解决过程做笔记如 ...

  3. 利用微信小程序实现web监控界面

    1.实现思路 利用小程序去调用公司zabbix的接口获取网站监控数据并展示出来. 2.准备阶段 1.小程序公众号 2.企业号 3.zabbix接口 3.实现过程

  4. 通过ssh隧道访问mysql(转载)

    我的机器可以连接服务器A,A可以访问服务器B上的mysql,但是我的机器不能访问B,所以我需要建立一个我本地机器到服务器A的ssh隧道来访问服务器B上的mysql. 理一下思路: 1.我要ssh的服务 ...

  5. sqoop 从oracle导数据到hive中,date型数据时分秒截断问题

    oracle数据库中Date类型倒入到hive中出现时分秒截断问题解决方案 1.问题描述: 用sqoop将oracle数据表倒入到hive中,oracle中Date型数据会出现时分秒截断问题,只保留了 ...

  6. 深入理解line

    什么是行间距? 古时候我们使用印刷机来出来文字.印刷出来的每个字,都位于独立的一个块中. 行间距,即传说中控制两行文字垂直距离的东东.在CSS中,line-height被用来控制行与行之间垂直距离. ...

  7. C语言8.3冒泡排序

    8.3.1 例8-5 题目:输入n个正整数,将他们从小到大排序后输出,要求使用冒泡排序法. 而在自己抄写代码的时候,出现了以下问题: # include<stdio.h> void bub ...

  8. OAuth授权

    重新梳理下授权认证模式. OWIN OWIN的英文全称是Open Web Interface for .NET.OWIN是针对.NET平台的开放Web接口. https://blog.csdn.net ...

  9. dfs_部分和问题

    给定整数a1,a2,....,an ,选若干数时它们的和为k. 解析:每个数有两种状态:加.不加. 全部n个数都决定其状态后进行判断.复杂度O(2n) 生成可行解空间多用dfs实现. import j ...

  10. JavaScript-onerror事件:图片加载失败后不显示

    HTML: <img src="http://www.mazey.net/images/upload/image/20170518/1495122198180663.gif" ...