当前位置: 首页 > news >正文

图解MySQL【日志】——Buffer Pool

Buffer Pool

什么是 Buffer Pool?

Buffer Pool 是数据库管理系统(DBMS)中的一块 Cache(内存区域),用来缓存从磁盘中读取到的 Data Pages(数据页)。Data Pages 通常是表中的数据行与索引数据,通过缓存 Data Pages,Buffer Pool 可以大大减少对磁盘的访问,提高 DB 的性能。


为什么需要 Buffer Pool?

1. 磁盘 I/O 性能瓶颈

  • 数据库通常将数据存储在磁盘中,而磁盘 I/O 相对于内存访问速度会慢很多,尤其是大型数据库,磁盘 I/O 成为性能的主要瓶颈。
  • Buffer Pool 的出现,完美地解决了这一问题,它通过缓存从磁盘中读取到的数据,在内存中保存一个副本,从而减少对磁盘的访问。

2. 减少磁盘读取,提高性能

  • 读数据:
    • 如果数据存在于 Buffer Pool 中,客户端直接读取。
    • 不在,去磁盘中读取,并加载到 Buffer Pool。
  • 修改数据:
    • 该数据在 Buffer Pool 中,直接修改 Buffer Pool 中数据所在的页,然后将其设置为脏页
    • 脏页(Dirty Pages):该页的内存数据和磁盘上的不一致了。
    • 后台写入(Flush):为了减少磁盘 I/O,不会立即将脏页写入磁盘,后续由后台线程择机异步将脏页写入磁盘。

Buffer Pool 缓存什么?

1. InnoDB 分页

  • InnoDB 会把存储的数据分为若干个【页】,以页(默认 16KB)作为磁盘交互的基本单位,因此 Buffer Pool 同样需要按【页】来划分。

2. Buffer Pool 初始化内存

  • MySQL 启动时,InnoDB 会为 Buffer Pool 申请一片连续的内存空间,然后按照默认的 16KB 大小划分出一个一个的,即缓存页

3. MySQL 为什么启动时虚拟内存很大,物理内存却很小?

  • 这是因为这些被分配的虚拟内存被访问时,OS 才会触发中断缺页机制,申请物理内存,接着将虚拟内存和物理地址建立映射关系。

4. Buffer Pool 中的各种页

  • 数据页:包含用户表中的行数据。
  • 索引页:存储主键索引和辅助索引结构。
  • undo 页:支持事务回滚的日志记录。
  • redo log 页:保证事务持久性的日志页。
  • 插入缓冲:加速非主键索引的插入操作。
  • 元数据:缓存数据库的元数据信息。
  • 锁页:缓存锁信息,避免重复加锁。

5. 查询一条记录只缓冲一条记录吗?

  • 懂得了 InnoDB 的分页机制后,我们就会知道磁盘交互的基本单位是页,查询一条记录时,会将整个页的数据加载到 Buffer Pool 中,再通过页中的【页目录】定位到需要查询的具体记录。

相关文章:

  • 算法日记19:SC71多元最短路(Floyd)
  • 什么事SSE SSE vs websocket
  • 【deepseek-r1模型】linux部署deepseek
  • 【Elasticsearch】搜索时分片路由
  • ollama-chat-ui-vue,一个可以用vue对接ollama的开源项目,可接入deepSeek
  • Chatgpt论文润色指令整理
  • LeetCode 0624.数组列表中的最大距离:只关心最小最大值
  • el-table 结合 slot 具名插槽遍历封装列表模板
  • jenkins自动发版vue前端笔记
  • JSON格式,C语言自己实现,以及直接调用库函数(一)
  • HTTP、HTTPS区别可靠性及POST为什么比GET安全的探讨
  • 结构风荷载理论与Matlab计算
  • Linux后台启动命令nohup并且MobaXterm后台启动断网也不关闭软件
  • 《探秘DeepSeek优化器:解锁模型训练的高效密码》
  • nodejs及搭建
  • 零基础用AI—AI伦理风险防控的十大核心策略与全球协同治理实践
  • 文章学习---经颅聚焦超声刺激(TUS)对灵长类动物大脑皮层激活的影响
  • SOME/IP--协议英文原文讲解6
  • Centos7 使用 yum 报错 Could not retrieve mirrorlist
  • Nmap:网络扫描与安全评估的多功能工具
  • 以军称已开始在加沙的新一轮大规模攻势
  • 一涉嫌开设赌场的网上在逃人员在山东威海落网
  • 商务部回应稀土出口管制问题
  • 全国人大常委会今年将初次审议检察公益诉讼法
  • 男子入户强奸高龄独居妇女致其死亡,法院:属实,已执行死刑
  • 费高云不再担任安徽省人民政府副省长