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

【MySQL | 第十一篇】InnoDB引擎

目录一、InnoDB的逻辑存储结构二、InnoDB的架构1.内存架构三、InnoDB的事务原理1.redo log2.undo log四、MVCC多版本并发控制1.基本概念2.MVCC中的三个隐式字段3.undo log版本链4.readView一、InnoDB的逻辑存储结构表空间idb文件表空间是 InnoDB 逻辑结构的最高层所有的数据、索引、甚至回滚信息都存放在表空间中。段Segment表空间是由各个段组成的。段是一个逻辑上的概念用来区分不同类型的数据。InnoDB 中的索引底层是 B 树因此段的划分和 B 树息息相关数据段 (Leaf node segment)即 B 树的叶子节点用来存放实际的数据行。索引段 (Non-leaf node segment)即 B 树的非叶子节点用来存放索引键值和指针。回滚段 (Rollback segment)用来存放 Undo Log回滚日志这是实现事务的 MVCC多版本并发控制和 Rollback回滚的关键。区Extent表空间的单元结构每个区的大小为1M。默认情况下InnoDB存储引擎页大小为16K即一个区中一共有64个连续的页。页Page页是 InnoDB 管理存储空间的基本单位也是磁盘 I/O 操作的最小单元。InnoDB 默认的页大小是16KB。行Row是我们在数据库里看到的一条条真实的记录。InnoDB 是面向行存储的。Trx_id:每次对某条记录进行改动时都会把对应的事务id赋值给trx_id隐藏列。Roll_pointer:每次对某条记录进行改动时都会把旧的版本写入到undo日志中然后这个隐藏列就相当于一个指针可以通过它来找到该记录修改前的信息。二、InnoDB的架构左侧为内存结构右侧为磁盘结构1.内存架构Buffer Pool缓冲池Change Buffer更改缓冲区Change Buffer存在的意义与聚集索引不同二级索引通常是非唯一的并且以相对随机的顺序插入二级索引。同样删除和更新可能会影响索引树中不相邻的二级索引页如果每一次都操作磁盘会造成大量的磁盘IO。有了ChangeBuffer之后我们可以在缓冲池中进行合并处理减少磁盘IO。Adaptive Hash Index自适应hash索引Log Buffer日志缓冲区三、InnoDB的事务原理我们知道事务具有ACID的特性但是这几种特性的底层原理是怎么样的1.redo log事务的持久性就是由事务的redo log去保证的。重做日志记录的是事务提交时数据页的物理修改是用来实现事务的持久性。该日志文件由两部分组成:重做日志缓冲(redo log buffer)以及重做日志文件(redo logfile)前者是在内存中后者在磁盘中。当事务提交之后会把所有修改信息都存到该日志文件中用于在刷新脏页到磁盘,发生错误时进行数据恢复使用。2.undo log事务的原子性由undo log去保证的。回滚日志用于记录数据被修改前的信息作用包含两个:提供回滚和MVCC(多版本并发控制)。undo log和redo log记录物理日志不一样它是逻辑日志。可以认为当delete一条记录时undo log中会记录一条对应的insert记录反之亦然当update一条记录时它记录一条对应相反的update记录。当执行rollback时就可以从undo log中的逻辑记录读取到相应的内容并进行回滚。Undo log销毁:undo log在事务执行时产生事务提交时并不会立即删除undo log因为这些日志可能还用于MVCC。Undo log存储:undo log采用段的方式进行管理和记录存放在前面介绍的rolback segment 回滚段中内部包含1024个undo logsegment.四、MVCC多版本并发控制1.基本概念当前读快照读MVCC全称Multi-Version Concurrency Control多版本并发控制。指维护一个数据的多个版本使得读写操作没有冲突快照读为MySQL实现MVCC提供了一个非阻塞读功能。MVCC的具体实现还需要依赖于数据库记录中的三个隐式字段、undo log日志、readView.2.MVCC中的三个隐式字段3.undo log版本链undo log回滚日志在insert、update、delete的时候产生的便于数据回滚的日志。当insert的时候产生的undolog日志只在回滚时需要在事务提交后可被立即删除。而update、delete的时候产生的undolog日志不仅在回滚时需要在快照读时也需要不会立即被删除。undo log 版本链不同事务或相同事务对同一条记录进行修改会导致该记录的undo log生成一条记录版本链表链表的头部是最新的旧记录链表尾部是最早的旧记录。4.readViewReadView(读视图)是快照读SQL执行时MVCC提取数据的依据记录并维护系统当前活跃的事务(未提交的)id。ReadView决定了快照读时返回版本链中的具体的那一个版本的记录。ReadView中包含了四个核心字段:规则不同的隔离级别生成ReadView的时机不同READ COMMITTED:在事务中每一次执行快照读时生成ReadView。REPEATABLE READ:仅在事务中第一次执行快照读时生成ReadView后续复用该ReadView。

相关文章:

【MySQL | 第十一篇】InnoDB引擎

目录 一、InnoDB的逻辑存储结构 二、InnoDB的架构 1.内存架构 三、InnoDB的事务原理 1.redo log 2.undo log 四、MVCC(多版本并发控制) 1.基本概念 2.MVCC中的三个隐式字段 3.undo log版本链 4.readView 一、InnoDB的逻辑存储结构 表空间&…...

Boss-Key:一键隐藏窗口的终极隐私保护解决方案

Boss-Key:一键隐藏窗口的终极隐私保护解决方案 【免费下载链接】Boss-Key 老板来了?快用Boss-Key老板键一键隐藏静音当前窗口!上班摸鱼必备神器 项目地址: https://gitcode.com/gh_mirrors/bo/Boss-Key 在现代办公环境中,保…...

Bili2text:3步完成B站视频转文字的高效解决方案

Bili2text:3步完成B站视频转文字的高效解决方案 【免费下载链接】bili2text Bilibili视频转文字,一步到位,输入链接即可使用 项目地址: https://gitcode.com/gh_mirrors/bi/bili2text 在信息获取日益依赖视频内容的今天,Bi…...

Krita-AI-Diffusion:如何通过中文本地化技术让全球用户无障碍使用AI绘画插件

Krita-AI-Diffusion:如何通过中文本地化技术让全球用户无障碍使用AI绘画插件 【免费下载链接】krita-ai-diffusion Streamlined interface for generating images with AI in Krita. Inpaint and outpaint with optional text prompt, no tweaking required. 项目…...

DataScienceR项目实战:Facebook评论提取与社交数据分析

DataScienceR项目实战:Facebook评论提取与社交数据分析 【免费下载链接】DataScienceR a curated list of R tutorials for Data Science, NLP and Machine Learning 项目地址: https://gitcode.com/gh_mirrors/da/DataScienceR DataScienceR是一个精心策划…...

3D高斯散射技术与视觉幻觉攻击原理详解

1. 3D高斯散射技术基础与视觉幻觉攻击原理3D高斯散射(3D Gaussian Splatting,简称3DGS)是近年来计算机视觉领域突破性的三维场景表示方法。与传统的体素或网格表示不同,3DGS通过数万到数百万个各向异性的高斯分布点云来表征场景几…...

SST(固态变压器)设计核心参数与方案选型表

设计关键点核心场景 / 需求推荐方案 / 关键参数拓扑结构中高压(≥10 kV)应用三级拓扑(AC/DC 隔离 DC/DC 可选 DC/AC)低压小功率应用两级矩阵拓扑隔离级拓扑功率>50 kW/800 V 母线(电池 / 数据中心&#x…...

Qt布局实战:用QSplitter和QSpacer打造一个可拖拽分割的仿IDE界面

Qt布局实战:用QSplitter和QSpacer打造一个可拖拽分割的仿IDE界面 在桌面应用开发中,界面布局的灵活性和用户体验往往决定了产品的专业程度。对于需要频繁切换视图的开发工具(如IDE),可拖拽分割的面板设计能极大提升工作…...

Node.js二维码生成终极指南:使用node-qrcode快速创建个性化二维码

Node.js二维码生成终极指南:使用node-qrcode快速创建个性化二维码 【免费下载链接】node-qrcode qr code generator 项目地址: https://gitcode.com/gh_mirrors/no/node-qrcode 在数字化时代,二维码已成为信息传递的重要桥梁。node-qrcode作为一款…...

Vue项目里给Element UI的el-tabs加个丝滑的左右滑动动画(附完整代码)

为Element UI的el-tabs注入丝滑左右滑动动画的实战指南 在VueElement UI的中后台开发中,el-tabs组件作为高频使用的导航控件,其默认的标签切换效果往往显得生硬呆板。本文将带你从零实现一个无侵入式的动画增强方案,只需三步即可让静态Tab切换…...

Boss-Key老板键:Windows窗口隐私保护的终极解决方案

Boss-Key老板键:Windows窗口隐私保护的终极解决方案 【免费下载链接】Boss-Key 老板来了?快用Boss-Key老板键一键隐藏静音当前窗口!上班摸鱼必备神器 项目地址: https://gitcode.com/gh_mirrors/bo/Boss-Key 在当今快节奏的工作环境中…...

C++ 选择 引用传递还是指针传递

在C编程中,选择引用传递(pass-by-reference)还是指针传递(pass-by-pointer)取决于具体的需求和上下文。下面是一些关于它们各自特点和适用场景的分析:总的来说,除非特殊需求(如需要表…...

【C++篇】类与对象:从面向过程到面向对象的跨越

前言 大家好,我是“我想吃余”,很高兴你能和我一起进入到C的学习中,我会将我的学习过程中的宝贵经验不遗余力的输入到文章中,希望可以帮助到你的学习。本文涵盖了从面向过程与面向对象的区别,到类的定义、访问限定符、…...

【C++】第六节—内存管理

1. C/C内存分配 程序运行过程中内存分区域,见下: 现在我们必须要清楚,写一个程序,程序里面的变量都放在我们刚才介绍的那个区域呢?见下题目(面试题,面试会考这样的题,那可得好好学清…...

告别手动水印:semi-utils如何让每张照片自动拥有专业标识

告别手动水印:semi-utils如何让每张照片自动拥有专业标识 【免费下载链接】semi-utils 一个批量添加相机机型和拍摄参数的工具,后续「可能」添加其他功能。 项目地址: https://gitcode.com/gh_mirrors/se/semi-utils 在摄影创作中,你是…...

长期项目使用Taotoken的月度账单与用量分析体验

长期项目使用Taotoken的月度账单与用量分析体验 1. 项目背景与Taotoken接入 我们的项目组在过去六个月中持续使用Taotoken平台进行AI原型开发。作为一个需要频繁调用不同大模型API的长期项目,我们选择了Taotoken作为统一接入层,主要基于其多模型聚合能…...

5分钟实战:用ArchivePasswordTestTool找回遗忘的压缩包密码

5分钟实战:用ArchivePasswordTestTool找回遗忘的压缩包密码 【免费下载链接】ArchivePasswordTestTool 利用7zip测试压缩包的功能 对加密压缩包进行自动化测试密码 项目地址: https://gitcode.com/gh_mirrors/ar/ArchivePasswordTestTool 你是否曾经面对着一…...

手把手教你用iDriver搞定华为服务器Win16驱动:从下载、校验到静默安装一条龙

华为服务器Windows Server 2016驱动管理全攻略:iDriver高效实践指南 在华为FusionServer系列服务器上部署Windows Server 2016时,驱动管理往往是系统管理员面临的第一个技术门槛。不同于消费级PC的即插即用体验,企业级服务器的硬件组件需要精…...

从‘Building kernel modules’报错聊起:Linux内核模块与NVIDIA驱动的‘爱恨情仇’

从内核模块构建失败看NVIDIA驱动的技术困境与解决方案 当你在Linux系统上安装NVIDIA显卡驱动时,最令人头疼的莫过于看到"Building kernel modules"报错。这个看似简单的错误背后,隐藏着Linux内核与闭源驱动之间复杂的技术博弈。本文将带你深入…...

Ultimate ASI加载器:3分钟掌握游戏模组安装的完整指南

Ultimate ASI加载器:3分钟掌握游戏模组安装的完整指南 【免费下载链接】Ultimate-ASI-Loader The Ultimate ASI Loader is a proxy DLL that loads custom .asi libraries into any game process. 项目地址: https://gitcode.com/gh_mirrors/ul/Ultimate-ASI-Load…...

科研小白也能搞定!手把手教你用UCSF ChimeraX处理PDB文件(附Linux/Windows安装避坑)

科研小白也能搞定!手把手教你用UCSF ChimeraX处理PDB文件(附Linux/Windows安装避坑) 第一次接触分子可视化软件时,面对满屏的原子和复杂的界面,很多生物、化学专业的研究生都会感到无从下手。记得我刚开始研究新冠病毒…...

Pixel Epic部署教程:Kubernetes集群中Pixel Epic服务的高可用部署方案

Pixel Epic部署教程:Kubernetes集群中Pixel Epic服务的高可用部署方案 1. 产品概述 Pixel Epic(像素史诗智识终端)是一款基于AgentCPM-Report大模型构建的研究报告辅助工具,采用独特的16-bit像素RPG风格界面设计。与传统AI工具不…...

心理疾病治疗指南:真实案例分享

行业痛点分析长沙心理医疗体系面临多重挑战。据《2022年长沙市心理健康白皮书》显示,约65%的潜在精神心理障碍患者因“病耻感”选择隐瞒症状,其中34%的轻症患者延误干预超过6个月。三甲医院平均挂号等待周期达72小时,单次咨询时长普遍不足30分…...

微信数据解析工具:从项目移除到合规思考

微信数据解析工具:从项目移除到合规思考 【免费下载链接】PyWxDump 删库 项目地址: https://gitcode.com/GitHub_Trending/py/PyWxDump 近期,一个曾经备受关注的微信数据解析工具 PyWxDump 项目正式宣告停止运营,这一事件引发了技术社…...

从零到一:手把手教你用KiCad复刻一块NUC980DK61YC开发板(附完整原理图与3D模型)

从零到一:手把手教你用KiCad复刻一块NUC980DK61YC开发板(附完整原理图与3D模型) 当市面上现成的开发板无法满足你的需求时,自己动手设计一块可能是最好的选择。本文将带你从零开始,使用完全开源的KiCad工具链&#xff…...

从HM55到HM77:详解1-3代酷睿笔记本主板芯片组,教你精准匹配升级CPU

从HM55到HM77:1-3代酷睿笔记本芯片组深度解析与CPU升级实战指南 十年前的老笔记本还能焕发第二春吗?答案藏在主板芯片组与CPU的匹配逻辑里。当我们拆开一台2010年前后的笔记本,HM55、HM65这些字母数字组合不仅代表芯片组型号,更是…...

别再傻傻分不清了!用Python代码实战带你搞懂准确率、精确率、召回率和F1分数

用Python代码实战解析分类模型四大核心指标 在数据科学项目中,评估分类模型性能是至关重要的一环。很多初学者虽然能背诵准确率、精确率、召回率和F1分数的定义,但当面对实际数据集时,仍然会困惑于这些指标的具体计算方式和应用场景。本文将通…...

【AHC】如何通过 `jmap` + `MAT` 分析 AHC 相关的 Direct Memory 泄漏?

如何通过 jmap + MAT 精准定位 async-http-client 的 Direct Memory 泄漏 发布时间:2026年02月08日 作者:九师兄 AI生成引擎:通义千问(Qwen) 在构建基于 async-http-client 3.0.6 的高吞吐 Flink 实时告警系统时,我们曾遭遇一次诡异的故障:服务运行数小时后,Kubernete…...

别再踩坑了!MybatisPlus更新字段为null的三种正确姿势(附UpdateWrapper实战)

MyBatis-Plus字段更新策略深度解析:三种方式精准控制NULL值写入 引言 在日常开发中,数据更新是最基础也最频繁的操作之一。但许多开发者在使用MyBatis-Plus进行字段更新时,经常会遇到一个看似简单却令人困惑的问题:为什么通过set方…...

CarPlay无线连接背后的‘握手’秘密:深入解读iAP2协议与蓝牙/Wi-Fi协同

CarPlay无线连接背后的‘握手’秘密:深入解读iAP2协议与蓝牙/Wi-Fi协同 当我们将iPhone靠近支持CarPlay的车载系统时,那个看似简单的无线连接背后,实际上隐藏着一场精密的数字芭蕾。这不是简单的蓝牙配对,而是一套由苹果精心设计的…...