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链往前找就行。

相关推荐
XDHCOM1 天前
ORA-32484重复列名错误,ORACLE数据库CYCLE子句故障修复与远程处理方案
数据库·oracle
翻斗包菜1 天前
PostgreSQL 日常维护完全指南:从基础操作到高级运维
运维·数据库·postgresql
呆瑜nuage1 天前
MySQL表约束详解:8大核心约束实战指南
数据库·mysql
liliangcsdn1 天前
Agent Memory智能体记忆系统的示例分析
数据库·人工智能·全文检索
那个失眠的夜1 天前
Mybatis延迟加载策略
xml·java·数据库·maven·mybatis
Rick19931 天前
SQL 执行流程
数据库·sql
M--Y1 天前
Redis常用数据类型
数据结构·数据库·redis
元宝骑士1 天前
FIND_IN_SET使用指南:场景、优缺点与MySQL优化策略
后端·mysql
猿小喵1 天前
MySQL慢查询分析与处理-第二篇
数据库·mysql·性能优化
Y001112361 天前
MySQL-进阶
开发语言·数据库·sql·mysql