• MySQL性能优化Buffer Pool详细介绍


    文章目录

      • 1.回顾缓冲池 Buffer Pool
      • 2.配置Buffer Pool的大小
      • 3.Buffer Pool:数据结构
        • 3.1.磁盘数据结构:数据页
        • 3.2.缓冲池数据结构:数据页(缓存页)
        • 3.3.缓存页对应的描述信息
      • 4.Buffer Pool:初始化
      • 5.Buffer Pool:free链表
      • 6.Buffer Pool:flush链表
      • 7.Buffer Pool:淘汰缓存页

    1.回顾缓冲池 Buffer Pool

    我们来看看下面这个更新SQL的流程图,不管流程多么复杂,有一点可以肯定的,最终数据落地,是落地在磁盘文件上。但是我们在对数据库执行增删改操作的时候,不可能直接更新磁盘上的数据的,因为如果你对磁盘进行随机读写操作,那速度是相当的慢,随便一个大磁盘文件的随机读写操作,可能都要几百毫秒。如果要是那么搞的话,可能你的数据库每秒也就只能处理几百个请求了!

    实际上我们对数据库执行增删改操作的时候,实际上主要都是针对内存里的Buffer Pool中的数据进行的,也就是你实际上主要是对数据库的内存里的数据结构进行了增删改。同时配合了后续的redo log、刷磁盘等机制和操作。所以Buffer Pool就是数据库的一个内存组件,里面缓存了磁盘上的真实数据,然后我们的Java系统对数据库执行的增删改操作,其实主要就是对这个内存数据结构中的缓存数据执行的。

    2.配置Buffer Pool的大小

    因为Buffer Pool本质其实就是数据库的一个内存组件,你可以理解为他就是一片内存数据结构,所以这个内存数据结构肯定是有一定的大小的,不可能是无限大的。这个 Buffer Pool默认情况下是128MB ,还是有一点偏小了,我们实际生产环境下完全可以对Buffer Pool进行调整

    比如我们的数据库如果是16核32G的机器,那么你就可以给Buffer Pool分配个2GB的内存,使用下面的配置就可以了。

    nnodb_buffer_pool_size = 2147483648

    我们可以先查看下我们innodb_buffer_pool_size的大小,执行如下SQL,可以发现为134217728

    134217728 /1024 / 1024 =128M

    show global variables like 'innodb_buffer_pool_size';

    设置大小

    SET GLOBAL innodb_buffer_pool_size= 32423423

    3.Buffer Pool:数据结构

    3.1.磁盘数据结构:数据页

    现在我们知道了数据库中一定有一片内存区域是Buffer Pool了,那么我们的数据是如何放在BufferPool中的?

    我们都知道数据库的核心数据模型就是表+字段+行的概念,也就是说我们都知道数据库里有一个一个的表,一个表有很多字段,然后一个表里有很多行数据,每行数据都有自己的字段值。所以大家觉得我们的数据是一行一行的放在Buffer Pool里面的吗?

    这就明显不是了,实际上MySQL对数据抽象出来了一个数据页的概念,他是把很多行数据放在了一个数据页里,也就是说我们的磁盘文件中就是会有很多的数据页,每一页数据里放了很多行数据,如下图所示。

  • 相关阅读:
    Spring和SpringBoot比较,解惑区别
    Android 将moudle导入项目做为library使用
    matlab矩阵计算
    代码随想录Day56 | 1143. 最长公共子序列 | 1035. 不相交的线 | 53. 最大子数组和
    LeetCode498. 对角线遍历(C++)
    1036 Boys vs Girls
    Acwing第 67 场周赛
    Elasticsearch:基于 Langchain 的 Elasticsearch Agent 对文档的搜索
    docker.1-应用(Application)部署容器化演进之路
    SG-Former:具有进化Token重新分配的自引导Transformer
  • 原文地址:https://blog.csdn.net/m0_73257876/article/details/126597995