MySQL|MySQL Redo与Undo日志详细解析
目录
- 1. Redo日志的介绍
- 1.1 Redo日志的作用
- 1.2 Redo日志的格式与类型
- 2. 写入Redo日志的流程(MTR)
- 3. Checkpoint机制
- 4. Undo日志介绍
- 5. MVCC
1. Redo日志的介绍 Redo日志是物理日志,记录的是页面的变化。
1.1 Redo日志的作用
- 提升数据库写入效率
- 保证数据库不丢数据,进行数据恢复
1.2 Redo日志的格式与类型
所谓REDO的组织方式,就是如何把需要的REDO内容记录到磁盘文件中,以方便高效的REDO写入,读取,恢复以及清理。我们这里把REDO从上到下分为三层:逻辑REDO层、物理REDO层和文件层。
- 逻辑REDO层
- 物理REDO层
- 文件层
文章图片
2. 写入Redo日志的流程(MTR)
- 用户线程的操作会首先写进
log buffer
中 log buffer
中的日志会顺序写入Redo逻辑日志中- 之后会落盘持久化存储到磁盘上
- 之后通知用户已经存储完成了
3. Checkpoint机制 Checkpoint是Redo日志中脏页的标记位,有以下两个作用:
- 维护Redo日志,方便清理
- 减小重启的工作量
文章图片
数据库恢复流程:
- 读取 checkpoint 信息?从 checkpoint 位置开始读取剩余日志
- 解析日志并按 space_no 与 page_id 构建 hash 表
- 应用 Redo 日志,Redo日志回放保证幂等性
- 解析 binlog 构建 xid 列表
- 扫描回滚段构建待提交事务列表
- 回滚掉未在 xid 列表中的事务
4. Undo日志介绍 Undo log是逻辑日志,记录的是数据的增量变化,它的作用是保证事务的原子性和事务并发控制。可以用于事务回滚,以及提供多版本机制(MVCC),解决读写冲突和一致性读的问题。
5. MVCC MVCC的意义:
- 读写互不阻塞;
- 降低死锁概率;
- 实现一致性读。
- 每个事务有一个单增的事务ID;
- 数据页的行记录中包含了DB_ROW_ID,DB_TRX_ID,DB_ROLL_PTR;
- DB_ROLL_PTR将数据行的所有快照记录都通过链表的结构串联了起来。
推荐阅读
- 与人为善,自然会有另一番景象
- java|查看MySQL初始密码并修改
- 音乐平台开发记录|基于springboot+vue(thymeleaf)+mysql下的自创音乐网站平台--CrushMusic(开发日志十)
- JAVA|12. 虚拟机与类加载机制
- 后端|MySQL 灵魂 16 问,你能撑到第几问()
- 矩阵|矩阵分析与应用+张贤达
- 打工旅行与心理学B|打工旅行与心理学B 19 你的生命是什么颜色
- 草莓与蝴蝶
- D56|D56 回顾与展望
- canal-1.1.5实时同步MySQL数据到Elasticsearch