MySQL-binlog、redolog和undolog的区别

区别:

1、binlog是mysql server层面的,用与数据备份和主从复制,每个执行引擎都有这个文件,比如Myisam和InnoDb

2、redoLog是InnoDb引擎特有的(实现了持久性),用于数据update,先将数据更新在内存,然后写入redolog,在空闲的时候写入磁盘

3、undlog也是InnoDb引擎特有的(实现了原子性),保存着更新前的语句,用于sql语句的回滚,MVCC用到了undolog,当读取的行被其他事务锁定时,可以从undolog找出该行记录之前的数据是什么,从而提供版本信息,保证用户的非一致性读取。

undolog---一条记录的每一次更新操作产生的 undo log 格式都有一个 roll_pointer 指针和一个 trx_id 事务id:

两阶段提交:在事务提交前redolog会有一个prepare阶段,这个阶段中先记录好redolog,然后在redolog提交commit之前,会记录binlog,记录好了之后会执行commit操作。

数据库崩溃能否使用undolog来恢复?

不能,因为undolog是循环写,写入磁盘后会将数据擦除。需要使用binlog来进行恢复,binlog是追加写。

相关推荐
计算机学姐7 分钟前
基于SpringBoot的校园资源共享系统【个性化推荐算法+数据可视化统计】
java·vue.js·spring boot·后端·mysql·spring·信息可视化
l1t18 分钟前
DeepSeek辅助编写的利用位掩码填充唯一候选数方法求解数独SQL
数据库·sql·算法·postgresql
墨月白27 分钟前
[QT] QT中的折线图和散点图
数据库·qt
龙潜月七38 分钟前
做一个背单词的脚本
数据库·windows·c#·aigc·程序那些事
我科绝伦(Huanhuan Zhou)1 小时前
DM数据库物理存储结构深度解析与理论实践
数据库·oracle
霖霖总总1 小时前
[小技巧23]全面理解 MySQL 的 WAL 机制:原理、影响与可观测性
数据库·mysql
列御寇1 小时前
MongoDB分片集概述
数据库·mongodb
又是忙碌的一天1 小时前
SpringMVC响应
java·服务器·数据库
W001hhh1 小时前
260110
java·数据库
冰暮流星2 小时前
sql语句之select语句的基本使用
数据库·sql·mysql