加入收藏 | 设为首页 | 会员中心 | 我要投稿 源码网 (https://www.900php.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

MySQL double write存在是怎样的意义

发布时间:2022-01-13 15:06:02 所属栏目:MySql教程 来源:互联网
导读:MySQL double write存在是怎样的意义,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。 背景: MySQL默认每个page size是16k,而OS通常最小I/O单元是4k,所以如果写page
      MySQL double write存在是怎样的意义,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。
 
背景:
 
     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不完整写时就没有地方可恢复的了。
 
看完上述内容是否对您有帮助呢?

(编辑:源码网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读