InnoDB引擎--存储结构与文件

2023-05-16

数据库是数据的集合,数据库管理系统(DBMS)是操作和管理数据库的应用程序。数据库应用主要有两类:OLAP(联机分析处理)和OLTP(联机事务处理)。
OLAP的主要特点是:

  • 实时性要求不高
  • 数据量大
  • 并发量小

OLTP的主要特点是:

  • 实时性要求高
  • 数据量小
  • 高并发
  • 要求满足ACID

Mysql体系架构

mysql是一种DBMS,其体系架构如下图所示:
这里写图片描述
mysql中集成的是插件式的存储引擎,InnoDB引擎是其中之一。存储引擎基于表而不是数据库:同一个数据库中根据不同表的访问操作需求可以选择不同的存储引擎。

InnoDB引擎

InnoDB引擎主要面对OLTP类应用

InnoDB引擎在mysql中处于文件和文件系统的上层,管理着对InnoDB引擎表的访问和更新。

InnoDB引擎逻辑存储结构

数据需要在一定的数据结构和组织结构下才能进行有效的管理。InnoDB表中的每行数据是基于B+树存储的,其中B+树中的顺序依据是主键的顺序,称为索引组织表。B+树存储在数据文件中,在B+树之外,InnoDB对数据文件中数据的管理和组织定义一个新的逻辑结构如下图所示:
这里写图片描述
所有的数据都被逻辑地存放在表空间中,对于整个数据库中的InnoDB表,可以共用一个表空间,也可以将表空间拆分为共享表空间和各个表私有的表空间。拆分后,私有表空间仅存储该表的数据、索引、和插入缓冲BitMap页,其他类的数据如回滚(undo)信息、系统事务信息等还是存储在共享表空间里。
共享表空间文件格式:
这里写图片描述
私有表空间文件格式:
这里写图片描述
表空间中的数据分类为各个段:数据段、索引段、回滚段等。为了 便于管理,在各个段中继续拆分为区,区再细化拆分为连续的页,页是InnoDB磁盘管理的最小单位(即InnoDB从磁盘读取和写入都是以页为单位进行的)。页中按关系表中的行来存储实际的关系数据。

在InnoDB中,表的数据均存储在B+树的叶子节点上,数据也是索引的一部分,即聚集索引。

InnoDB索引页的文件格式:
这里写图片描述

先看FIL Header:
这里写图片描述
FIL Header中包含了索引页作为文件的信息。存储了指向上个页和下个页的指针,即索引页之间是通过链表连接起来的;同时还存储了该页的LSN(Log Squence Number),用于支持CheckPoint。

再看INDEX Header:
这里写图片描述
INDEX Header中包含了对于索引页作为索引的信息。存储了索引页中记录的数量,索引节点的类型(根节点、非叶结点、叶结点),页目录槽数(Page Directory)等信息。

然后就是User Records行记录了,存储了B+树索引非叶节点数据和叶结点数据,从图中可以看出User Records在物理上并不有序,但是逻辑上是以单链表有序的,顺序为主键顺序

最后来看页目录(Page Directory)。User Records是以单链表组织的,一个页的大小是16K,最多可以存储近8000行数据,查询某一个行时需要顺序遍历所有行,引入Page Directory对User Records进行二分查找,提高页内数据查询效率,如下图所示:
这里写图片描述

最终,以表、段、区、页的逻辑结构为载体,构建出InnoDB表B+树的逻辑结构如下图:
这里写图片描述

Mysql相关文件

参数文件

mysql数据库的配置文件,包含了各类系统参数。

日志文件

mysql中常见的日志文件:

  • error log:记录了mysql启动、运行、关闭过程。
  • binary log:记录了对mysql数据库执行更改(不包含查询)的所有操作。
  • slow query log:记录执行超过指定时间值的SQL语句。
  • query log:记录所有对mysql数据库请求的信息。
表结构文件

无论选用什么存储引擎,mysql会对定义的表和视图生成(表名.frm)文件用以存储表和视图的结构定义。

以下为InnoDB引擎的文件:

表空间文件
  • 共享表空间文件:ibdata1
  • 私有表空间文件:表名.ibd
redo log文件

ib_logfile0 与 ib_logfile1,用于支持事务的持久性。

MySQL技术内幕 InnoDB存储引擎 第2版
https://blog.jcole.us/innodb/
mysql 官方手册

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

InnoDB引擎--存储结构与文件 的相关文章

随机推荐

  • Linux系统之部署Go语言开发运行环境

    Linux系统之部署Go语言开发运行环境 一 Go语言介绍1 Go语言简介2 Go语言的撰写风格 二 本地环境检查1 检查系统版本2 检查系统内核版本 三 yum直接安装go1 检查yum仓库2 安装go3 创建环境变量 四 二进制安装Go
  • 解决vnc view看不到图形界面的问题

    有时候用VNC View打开远程linux桌面时 xff0c 桌面显示不出来 xff0c 只有一个灰色背景加上一个命令行 这时候需要在vnc server上设置一下 xff1a 编辑 root vnc xstartup root 64 lo
  • C# delegate、event、Action、Func使用案例解析

    C 中 delegate event Action Func使用案例解析 一 xff1a delegate与event配合使用 public static class Evt Test public static string strEqu
  • Nginx 使用 logrotate 进行日志滚动

    Nginx 日志滚动 xff08 官方 xff09 向 Nginx 主进程发送 USR1信号 USR1信号量被 Nginx 自定义了 xff0c 为重新打开日志 xff1b 当 kill 命令发送 USR1时 xff0c nginx 会重新
  • Softmax()函数的溢出问题笔记

    首先 xff0c 回顾softmax函数的定义 xff1a 按照这个定义 xff0c softmax 在Python解释器中可以这样实现 xff1a import numpy as np def softmax a exp a 61 np
  • 进公司一年,怎么跟老板提涨工资?

    网友提问 xff1a 进公司一年 xff0c 怎么跟老板提涨工资 xff1f 无忧专家 xff1a 薪资不是 你想加 xff0c 想加就能加的 xff0c 好多人鼓足勇气开口说出了加薪理由 xff0c 却被老板轻描淡写的一句话给噎住了喉咙
  • what is Cardinality?

    在数学意义上 xff0c cardinality 基数或者势 指集合内元素的个数 在数据库的相关资料中 xff0c 往往会看到cardinality这个术语 Base cardinality is the number of rows in
  • CAS单点登录开源框架解读(六)--CAS单点登录服务端认证之用户认证跳转

    用户认证之后如何执行后续跳转 在上一章节中 xff0c 我们知道了默认CAS服务端是如何通过配置文件实现用户登录名和密码的认证 xff0c 下面我们将继续对认证之后的动作处理进行分析 1 发送TGT之行为状态sendTicketGranti
  • cocos creator新缓动系统-cc.tween

    前言 一直对于cocos creator的action系统有着深深的埋怨 xff0c 原因是用起来太麻烦了 习惯了Unity的Tween插件的用法 xff0c 我也试着自己封装了下action系统 xff0c 用起来像Tween那样 xff
  • Direct UI

    有个坑爹的说法 xff1a 其实Direct UI只是一个思想 xff0c 要实现这个思 想 xff0c 还要靠自己 采用windows方式用api或gdi实现ui的绘制 DirectUI意为直接在父窗口上绘图 Paint on paren
  • 个人学习记录-AD2021

    有结点的一侧有电气属性 xff0c 用于连接导线 当捕捉格较大时 xff0c 更改捕捉栅格 视图 栅格 设置捕捉栅格 designator 位号 xff0c 一般用R U C T 代替 link 链接 填写元件名称及购买商 管脚name处
  • Linux Zram配置使用(特定平台&个人使用,maybe不具普适性)

    内核配置 xff1a CONFIG ZSMALLOC 61 y CONFIG ZRAM 61 y CONFIG SWAP 61 y swapon dev zram0 Function not implemented报错原因是CONFIG S
  • 2021-03-15

    float型变量占用32bit xff0c 即4个byte的内存空间 我们先来看下浮点数二进制表达的三个组成部分 三个主要成分是 xff1a Sign xff08 1bit xff09 xff1a 表示浮点数是正数还是负数 0表示正数 xf
  • 2021-03-18

    包络面与载波信号的确定
  • 2021-03-19

    输出 数字直角三角形 1 2 3 4 5 6 7 8 9 10 11 12 可根据需要增加行数 public class trangle 64 param args public static void main String args T
  • 2021-03-19

    switch语句实现成绩选择 注意强制转换 import java util Scanner public class Grade Switch 64 param args public static void main String ar
  • 2021-04-03

    Java代码 importjava util Scanner public classTest public static voidmain String args p br Scanner scan 61 newScanner Syste
  • 2021年寒假

    2022年1月4日 周二 雨雪 主要内容 xff1a 测试学校周雄短路的板子 xff0c 焊接新板子 上午11 00开始 xff0c 首先准备好电源 xff0c 热风枪 xff0c 前一天晚上已经改完的板子 第一次上电 测得最终输出5v 1
  • JavaScript 异步编程

    异步的概念 异步 xff08 Asynchronous async xff09 是与同步 xff08 Synchronous sync xff09 相对的概念 在我们学习的传统单线程编程中 xff0c 程序的运行是同步的 xff08 同步不
  • InnoDB引擎--存储结构与文件

    数据库是数据的集合 xff0c 数据库管理系统 xff08 DBMS xff09 是操作和管理数据库的应用程序 数据库应用主要有两类 xff1a OLAP xff08 联机分析处理 xff09 和OLTP xff08 联机事务处理 xff0