登录
/
注册
首页
论坛
其它
首页
科技
业界
安全
程序
广播
Follow
关于
签到
每天签到奖励2-10圆
导读
排行榜
TG频道
发帖说明
登录
/
注册
账号
自动登录
找回密码
密码
登录
立即注册
搜索
搜索
关闭
CSDN热搜
程序园
精品问答
技术交流
资源下载
本版
帖子
用户
软件
问答
教程
代码
写记录
VIP申请
VIP网盘
网盘
联系我们
发帖说明
每日签到
道具
勋章
任务
淘帖
动态
分享
留言板
导读
设置
我的收藏
退出
腾讯QQ
微信登录
返回列表
首页
›
业界区
›
安全
›
MySQL 02 日志系统:一条SQL更新语句是如何执行的? ...
MySQL 02 日志系统:一条SQL更新语句是如何执行的?
[ 复制链接 ]
要燥
2025-9-25 21:10:30
比如执行一条更新语句:
update T set c=c+1 where ID=2;
复制代码
首先,更新语句也会走一遍查询语句的流程。除此以外,更新还涉及两个日志模块,分别是redo log和binlog。
redo log
MySQL的更新用到了WAL(Write-Ahead Logging)技术,关键点就是先写日志,再写磁盘。具体来说,当有一条记录需要更新时,InnoDB引擎先将记录写到redo log并更新内存,这时更新就可以算完成了。之后,InnoDB会在适当的时候将这个操作记录更新到磁盘里。
InnoDB的redo log是固定大小的,比如可以配置为一组4个文件,每个文件大小为1GB。它的写法是从头开始写,写到末尾后又继续从开头写,如下所示:
这里,write pos是当前记录的位置,check point是当前要擦除的位置。当记录更新到磁盘,check point会向前移动。当有新的更新操作要记录,write pos会向前移动。
因此,有可能write pos会追上check point。这时候就不能执行新的更新,需要先将一部分记录更新到磁盘。
有了redo log,InnoDB就可以保证即使数据库发生异常重启,之前提交的记录都不会丢失,这个能力称为
crash-safe
。
当设置innodb_flush_log_at_trx_commit=1,表示每次事务的redo log都直接持久化到磁盘。推荐设置,这样可以保证MySQL异常重启后数据不丢失。
binlog
redo log是InnoDB引擎特有的日志,而binlog是Server层的日志。最开始,由于MySQL自带引擎为MyISAM,并没有crash-safe的能力,因此后来引入InnoDB后,同时使用这两种日志。binlog的主要作用是做
备份
。
当设置sync_binlog=1,表示每次事务的binlog都持久化到磁盘。推荐设置,这样可以保证MySQL异常重启后binlog不丢失。
两者的具体区别如下:
redo log是InnoDB引擎特有的,而binlog是Server层实现的。
redo log是物理日志,记录“在某个数据页上做了什么修改”;binlog是逻辑日志,记录这个语句的原始逻辑,比如“给ID=2的行的c字段加1”。
redo log是循环写,空间固定;binlog是追加写,写完一个文件会写下一个文件。
介绍完两个日志的概念,来看执行器+InnoDB引擎完成前面的更新语句的流程:
执行器找到ID=2这一行,若这一行所在的数据页在内存中,则直接返回给执行器,否则需要先从磁盘读入数据页再返回。
执行器拿到引擎返回的数据,做c+1的操作,得到新数据。
引擎将新数据更新到内存,同时将这个更新操作记录到redo log里,此时redo log处于prepare状态。然后告知执行器执行完成,随时可以提交事务。
执行器生成该操作的binlog,并将binlog写入磁盘。
执行器调用引擎的提交事务接口,引擎把刚写入的redo log改成commit状态,更新完成。
上面redo log写入拆为了prepare和commit,就是
两阶段提交
。
为什么需要两阶段提交
以前面的更新语句为例。假设ID=2的行中,字段c初始为0。并假设执行update过程中,写完第一个日志但还没写完第二个日志时发生了crash。
如果不使用两阶段提交,那么无非两种情况:
先写redo log再写binlog。当redo log写完,系统即使崩溃,仍能恢复数据c=1。但binlog里并没有记录更新语句,之后要用binlog去做备份时,恢复出来的c=0,与原库不同。
先写binlog再写redo log。当binlog写完之后crash,由于redo log还没写,崩溃后恢复数据c=0。但由于binlog已写完,之后用binlog去做备份时,恢复出来的c=1,与原库不同。
即如果不使用两阶段提交,那么恢复临时库或主从备份就可能出现不一致。
来源:程序园用户自行投稿发布,如果侵权,请联系站长删除
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
MySQL
日志
系统
一条
SQL
相关帖子
MySQL面试题汇总
关键词SEO相关搜索下拉框优化系统按天扣费系统全开源
MYSQL主从配置
WPF应用最小化到系统托盘
集成移动端推送功能的系统通知公告数据库设计
SQL优化实战:标量子查询改写外连接的真实案例
Cloudreve网盘系统程序
多cms养站系统【AI原创】程序
读高性能MySQL(第4版)笔记15_备份与恢复(下)
Windows系统下Visual Studio Code (VSCode)中C++的环境配置
vip免费申请,1年只需15美金$
回复
使用道具
举报
提升卡
置顶卡
沉默卡
喧嚣卡
变色卡
千斤顶
照妖镜
相关推荐
安全
MySQL面试题汇总
0
896
崔瑜然
2025-10-07
程序
关键词SEO相关搜索下拉框优化系统按天扣费系统全开源
1
15
新程序
2025-10-08
安全
MYSQL主从配置
0
548
时思美
2025-10-09
业界
WPF应用最小化到系统托盘
0
451
癖艺泣
2025-10-09
安全
集成移动端推送功能的系统通知公告数据库设计
0
298
楞粳
2025-10-09
业界
SQL优化实战:标量子查询改写外连接的真实案例
0
165
靳谷雪
2025-10-10
程序
Cloudreve网盘系统程序
0
6
新程序
2025-10-10
程序
多cms养站系统【AI原创】程序
0
10
新程序
2025-10-10
安全
读高性能MySQL(第4版)笔记15_备份与恢复(下)
1
2
蓝娅萍
2025-10-10
安全
Windows系统下Visual Studio Code (VSCode)中C++的环境配置
0
150
吉娅寿
2025-10-10
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
|
立即注册
回复
本版积分规则
回帖并转播
回帖后跳转到最后一页
浏览过的版块
业界
代码
程序
签约作者
程序园优秀签约作者
发帖
要燥
2025-9-25 21:10:30
关注
0
粉丝关注
19
主题发布
板块介绍填写区域,请于后台编辑
财富榜{圆}
anyue1937
9999501
dage888
999994
富账慕
10007
4
匝抽
9986
5
孙淼淼
9992
6
柴古香
9993
7
筒濂
9982
8
凌彦慧
9991
9
崔瑜然
9984
10
慢秤
9979
查看更多