从一条更新SQL的执行过程窥探InnoDB之REDOLOG
怎么入门数据库编程?需要学习哪些知识点?这是新手们刚接触编程时常见的问题;下面golang学习网就来给大家整理分享一些知识点,希望能够给初学者一些帮助。本篇文章就来介绍《从一条更新SQL的执行过程窥探InnoDB之REDOLOG》,涉及到MySQL、mongodb、数据库,有需要的可以收藏一下
1 前言
数据库为了取得更好的读写性能,InnoDB会将数据缓存在内存中(InnoDB Buffer Pool),对磁盘数据的修改也会落后于内存,这时如果进程或机器崩溃,会导致内存数据丢失,为了保证数据库本身的一致性和持久性,InnoDB维护了REDO LOG。修改Page之前需要先将修改的内容记录到REDO中,并保证REDO LOG早于对应的Page落盘,也就是常说的WAL,Write Ahead Log。当故障发生导致内存数据丢失后,InnoDB会在重启时,通过重放REDO,将Page恢复到崩溃前的状态。
2 MYSQL更新语句的执行过程
2.1 MYSQL的体系结构
大体来说,MySQL 可以分为 客户端、Server层和存储引擎层三大部分,如图所示。
Server 层包括连接器、查询缓存、分析器、优化器、执行器等,涵盖 MySQL 的大多数核心服务功能,以及所有的内置函数(如日期、时间、数学和加密函数等),所有跨存储引擎的功能都在这一层实现,比如存储过程、触发器、视图等。
存储引擎层负责数据的存储和提取。其架构模式是插件式的,支持 InnoDB、MyISAM、Memory 等多个存储引擎。现在最常用的存储引擎是 InnoDB,它从 MySQL 5.5.5 版本开始成为了默认存储引擎。

2.2 更新SQL的执行
当我们执行一条更新SQL时是如何执行的呢,下面执行一条简单的SQL更新语句(默认存储引擎InnoDB)
update T set c=c+1 where ID=2;
第一步:连接器
先通过连接器连接到这个数据库上。连接器负责跟客户端建立连接、校验用户名密码的正确性,同时获取该用户的权限放到缓存中、维持和管理连接
第二步:缓存
连接建立完成后,如果执行的是SELECT查询 语句会查询缓存中是否存在该SQL的结果集,如果存在结果则再校验用户表和数据的权限最终将查询到的结果返回。如果是UPDATE,DELETE等更新操作,那么跟这个表有关的查询缓存会置为失效,所以这条语句就会把表 T 上所有缓存结果都清空。
第三步:分析器
如果没有命中查询缓存,就要开始真正执行语句了。首先,MySQL 需要知道你要做什么,因此需要对 SQL 语句做解析。
分析器先会做“词法分析”。你输入的是由多个字符串和空格组成的一条 SQL 语句,MySQL 需要识别出里面的字符串分别是什么,代表什么。例如该语句中c列在表T中是否存在等。
做完了这些识别以后,就要做“语法分析”。根据词法分析的结果,语法分析器会根据语法规则,判断你输入的这个 SQL 语句是否满足 MySQL 语法。该SQL语句中的update、where 等是否符合SQL语法
第四步:优化器
经过了分析器,MySQL 就知道你要做什么了。在开始执行之前,还要先经过优化器的处理。优化器是在表里面有多个索引的时候,决定使用哪个索引;或者在一个语句有多表关联(join)的时候,决定各个表的连接顺序;优化器决定要使用 ID 这个索引。指定索引也就指定了后面的执行器需要调用存储引擎的哪个接口进行执行。
第五步:执行器
MySQL 通过分析器知道了你要做什么,通过优化器知道了该怎么做,于是就进入了执行器阶段,开始执行语句。开始执行的时候,要先判断一下你对这个表 T 有没有执行查询的权限,如果没有,就会返回没有权限的错误。执行器负责具体执行,找到这一行,然后更新。

2.3 InnoDB存储引擎引入REDOLOG
Mysql本身有自己的日志记录binlog(归档日志:分为row,statement两种模式),但是只依靠binlog是没有crash-safe能力的,所以在存储引擎层InnoDB使用另外一套日志系统redolog来实现crash-safe能力。同时为了取得更好的读写性能,InnoDB会将数据缓存在内存中(InnoDB Buffer Pool),对磁盘数据的修改也会落后于内存,这时如果进程或机器崩溃,会导致内存数据丢失,从而保证数据库本身的一致性和持久性。修改Page之前需要先将修改的内容记录到REDO中,并保证REDO LOG早于对应的Page落盘,也就是常说的WAL,Write Ahead Log。当故障发生导致内存数据丢失后,InnoDB会在重启时,通过重放REDO,将Page恢复到崩溃前的状态。
那么我们需要什么样的REDO呢?
首先,REDO的维护增加了一份写盘数据,同时为了保证数据正确,事务只有在他的REDO全部落盘才能返回用户成功,REDO的写盘时间会直接影响系统吞吐,显而易见,REDO的数据量要尽量少。其次,系统崩溃总是发生在始料未及的时候,当重启重放REDO时,系统并不知道哪些REDO对应的Page已经落盘,因此REDO的重放必须可重入,即REDO操作要保证幂等。最后,为了便于通过并发重放的方式加快重启恢复速度,REDO应该是基于Page的,即一个REDO只涉及一个Page的修改。
数据量小是Logical Logging的优点,而幂等以及基于Page正是Physical Logging的优点。InnoDB采取了一种称为Physiological Logging的方式,来兼得二者的优势。所谓Physiological Logging,就是以Page为单位,但在Page内以逻辑的方式记录。举个例子,一种作用于Page类型的REDOLOG中记录了对Page中一个Record的修改,方法如下:
(Page ID,Record Offset,(Filed 1, Value 1) … (Filed i, Value i) … )
其中,PageID指定要操作的Page页,Record Offset记录了Record在Page内的偏移位置,后面的Field数组,记录了需要修改的Field以及修改后的Value。
2.4 REDOLOG的记录内容

其中Type就是记录的作用对象(根据REDO记录不同的作用对象,可划分为三个大类:作用于Page,作用于Space以及提供额外信息的Logic类型),Space ID和Page Number唯一标识一个Page页,这三项是所有REDO记录都需要有的头信息。
后面的是MLOG_REC_UPDATE_IN_PLACE类型(作用于Page)独有的,其中Record Offset用给出要修改的记录在Page中的位置偏移,Update Field Count说明记录里有几个Field要修改,紧接着对每个Field给出了Field编号(Field Number),数据长度(Field Data Length)以及数据(Filed Data)
3 总结
通过对一个更新SQl语句执行过程的跟踪,了解熟悉Mysql的执行过程,了解REDOLOG的数据的内容格式,从根本上理解REDOLOG的设计的思路和原理,为以后的应用系统的开发和设计提供思想上的借鉴和实践。
本篇关于《从一条更新SQL的执行过程窥探InnoDB之REDOLOG》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于数据库的相关知识,请关注golang学习网公众号!

- 上一篇
- 教你从创建数据表到实现最基础增删改查的实现全过程,小白也能轻松学会【带附件】

- 下一篇
- 手把手教你定位线上MySQL锁超时问题,包教包会
-
- 光亮的老鼠
- 这篇博文出现的刚刚好,细节满满,真优秀,码起来,关注楼主了!希望楼主能多写数据库相关的文章。
- 2023-03-03 08:19:07
-
- 高高的星星
- 这篇文章太及时了,博主加油!
- 2023-03-02 15:10:07
-
- 自觉的服饰
- 太给力了,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,看完之后很有帮助,总算是懂了,感谢老哥分享文章内容!
- 2023-02-28 11:17:21
-
- 个性的小天鹅
- 很棒,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,看完之后很有帮助,总算是懂了,感谢博主分享博文!
- 2023-02-28 05:30:24
-
- 爱笑的店员
- 这篇技术文章真是及时雨啊,很详细,感谢大佬分享,已收藏,关注楼主了!希望楼主能多写数据库相关的文章。
- 2023-02-25 23:50:07
-
- 体贴的香菇
- 太详细了,码起来,感谢师傅的这篇技术文章,我会继续支持!
- 2023-02-25 08:02:06
-
- 数据库 · MySQL | 1小时前 |
- MySQL分区表查询优化技巧
- 419浏览 收藏
-
- 数据库 · MySQL | 12小时前 |
- MySQL数据归档方法与工具详解
- 494浏览 收藏
-
- 数据库 · MySQL | 12小时前 |
- MySQL常用命令20个必备操作指南
- 149浏览 收藏
-
- 数据库 · MySQL | 16小时前 |
- MySQL数据库详解:核心功能与优势全解析
- 236浏览 收藏
-
- 数据库 · MySQL | 21小时前 |
- MySQL基础命令详解,新手必看操作指南
- 436浏览 收藏
-
- 数据库 · MySQL | 23小时前 |
- MySQL中英文界面切换方法详解
- 366浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQL数据库特点与优势详解
- 194浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQL性能监控设置与核心指标解析
- 252浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQL中文乱码解决方法汇总
- 119浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQL增删改查语法速查表大全
- 434浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- 主键外键关系详解:MySQL关联解析
- 191浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQL安装D盘配置教程
- 120浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 511次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 498次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
-
- 千音漫语
- 千音漫语,北京熠声科技倾力打造的智能声音创作助手,提供AI配音、音视频翻译、语音识别、声音克隆等强大功能,助力有声书制作、视频创作、教育培训等领域,官网:https://qianyin123.com
- 233次使用
-
- MiniWork
- MiniWork是一款智能高效的AI工具平台,专为提升工作与学习效率而设计。整合文本处理、图像生成、营销策划及运营管理等多元AI工具,提供精准智能解决方案,让复杂工作简单高效。
- 229次使用
-
- NoCode
- NoCode (nocode.cn)是领先的无代码开发平台,通过拖放、AI对话等简单操作,助您快速创建各类应用、网站与管理系统。无需编程知识,轻松实现个人生活、商业经营、企业管理多场景需求,大幅降低开发门槛,高效低成本。
- 228次使用
-
- 达医智影
- 达医智影,阿里巴巴达摩院医疗AI创新力作。全球率先利用平扫CT实现“一扫多筛”,仅一次CT扫描即可高效识别多种癌症、急症及慢病,为疾病早期发现提供智能、精准的AI影像早筛解决方案。
- 232次使用
-
- 智慧芽Eureka
- 智慧芽Eureka,专为技术创新打造的AI Agent平台。深度理解专利、研发、生物医药、材料、科创等复杂场景,通过专家级AI Agent精准执行任务,智能化工作流解放70%生产力,让您专注核心创新。
- 256次使用
-
- golang MySQL实现对数据库表存储获取操作示例
- 2022-12-22 499浏览
-
- 搞一个自娱自乐的博客(二) 架构搭建
- 2023-02-16 244浏览
-
- B-Tree、B+Tree以及B-link Tree
- 2023-01-19 235浏览
-
- mysql面试题
- 2023-01-17 157浏览
-
- MySQL数据表简单查询
- 2023-01-10 101浏览