MySQL中有哪些日志类型?

MySQL有binlog、redo log和undo log三种日志,其中binlog 负责主从复制和数据恢复,redo log保证崩溃后数据不丢失,undo log支撑事务回滚和MVCC。

1.binlog

binlog 是server层的日志,记录的是逻辑操作,也就是原始SQL或者行变更前后的值。

它的核心场景是主从同步,从库拉取主库到binlog重放一遍就能保持数据一致。

另外,做数据恢复的时候,也是靠binlog配合全量备份回放到指定时间点。

2.redo log是InnoDB引擎独有的,记录的是物理变更,具体就是"某个数据页的某个偏移量改成了什么值"。

它的作用是崩溃恢复(crash-safe),基于WAL(Write Ahead Log)机制,MySQL挂了重启后,InnoDB会用redo log把没来得及刷盘的脏页恢复出来。

redo log是循环写的,空间固定,写满了就得等checkpoint推进才能继续。

3.undo log也是InnoDB引擎的逻辑日志,记录的是数据修改前的旧值。

事务回滚的时候,就靠undo log把数据改回去,另外MVCC的快照读也依赖它,别的事务要读历史版本,顺着undo log链往前找就行。

相关推荐
笨蛋不要掉眼泪2 小时前
Redis核心数据类型与命令
数据库·redis·缓存
小唐同学爱学习2 小时前
短链接修改之写锁
spring boot·redis·后端·mysql
数据知道3 小时前
一文掌握 MongoDB 详细安装与配置(Windows / Linux / macOS 全平台)
linux·数据库·windows·mongodb·macos
Knight_AL3 小时前
Flink 状态管理详细总结:State 分类、Keyed State 实战、Operator State、TTL、状态后端选型
前端·数据库·flink
ADRU3 小时前
Dify API 数据库连接与 Session 管理架构调研
数据库·架构
zhglhy3 小时前
Redis Cluster 的数据分片机制
数据库·redis·缓存
奥特曼_ it3 小时前
【NLP舆情分析】基于python微博舆情分析可视化系统(完整系统源码+数据库+详细部署教程)✅
数据库·python·自然语言处理
Mr__Miss3 小时前
Mysql的redo log和undo log
数据库
luoluoal3 小时前
基于python的web渗透测试工具(源码+文档)
python·mysql·django·毕业设计·源码