背景:MySQL默认每个page size是16k,而OS通常最小I/O单元是4k,所以如果写page时可能需要调用4次OS I/O才能完成。假定在执行两次时DB crash了,这时page只写了一部分,就产生了partial write(不完整写)。MySQL double write的设定就是为了在发生partial write时任然保证已经commit的数据不丢失,以及数据文件不损坏。
疑惑:MySQL double write很多文章中有介绍,但理解过程中有一些问题:
既然写double write buffer也是写硬盘ibdata1文件,这块和直接写.ibd 文件又有什么区别?
写double write buffer 也是写16k page 也可能出现分裂情况吧?
只是因为写double write buffer是顺序写速度快一些?
解疑:其实MySQL double write主要存在机制是在恢复时:
1> .ibd数据文件page在发生partial write不完整写时可以从double write文件恢复2> double write文件page损坏时,因为此时.ibd数据文件没有被修改,可以直接利用已经commit的redo恢复前滚3> redo page会发生partial write吗?redo page大小是512字节小于4k os最小io不会存在partial write问题
以上,想想如果没有double write机制,仅仅只存在.ibd文件,直接写在partial write不完整写时就没有地方可恢复的了。
附图:

MySQL double write存在意义
来源:这里教程网
时间:2026-03-01 15:06:06
作者:
编辑推荐:
- MySQL double write存在意义03-01
- Mysql5.7 的错误日志中最常见的note日志03-01
- mysql 学习笔记之搭建MHA高可用03-01
- MySQL truncate原理03-01
- mysql学习笔记之监控与优化03-01
- mysql学习笔记之基础测试03-01
- MySQL关于事务常见的问题03-01
- 项目管理软件这么多,为什么我只推荐它?03-01
下一篇:
相关推荐
-
雷神推出 MIX PRO II 迷你主机:基于 Ultra 200H,玻璃上盖 + ARGB 灯效
2 月 9 日消息,雷神 (THUNDEROBOT) 现已宣布推出基于英
-
制造商 Musnap 推出彩色墨水屏电纸书 Ocean C:支持手写笔、第三方安卓应用
2 月 10 日消息,制造商 Musnap 现已在海外推出一款 Oce
热文推荐
- MySQL double write存在意义
MySQL double write存在意义
26-03-01 - mysql 学习笔记之搭建MHA高可用
mysql 学习笔记之搭建MHA高可用
26-03-01 - MySQL truncate原理
MySQL truncate原理
26-03-01 - mysql学习笔记之监控与优化
mysql学习笔记之监控与优化
26-03-01 - 项目管理软件这么多,为什么我只推荐它?
项目管理软件这么多,为什么我只推荐它?
26-03-01 - MYSQL_架构之主从_MHA
MYSQL_架构之主从_MHA
26-03-01 - 如何利用运维面板进行数据库一键安装和管理?
如何利用运维面板进行数据库一键安装和管理?
26-03-01 - DBbrain诊断日 | 深入揭秘DBbrain智能优化引擎
DBbrain诊断日 | 深入揭秘DBbrain智能优化引擎
26-03-01 - MySQL慢日志优化的一个案例分析
MySQL慢日志优化的一个案例分析
26-03-01 - ORA-00742:Log read detects lost writein thread 1 sequence 1202 block 137840 (2
