温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

MySQL double write存在是怎样的意义

发布时间:2021-10-08 16:27:48 阅读:167 作者:柒染 栏目:MySQL数据库
亿速云mysql数据库,读写分离,安全稳定,弹性扩容,低至0.3元/天!! 点击查看>>

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不完整写时就没有地方可恢复的了。

附图:

MySQL double write存在是怎样的意义

MySQL double write存在是怎样的意义

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注亿速云行业资讯频道,感谢您对亿速云的支持。

亿速云「云数据库 MySQL」免部署即开即用,比自行安装部署数据库高出1倍以上的性能,双节点冗余防止单节点故障,数据自动定期备份随时恢复。点击查看>>

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

原文链接:http://blog.itpub.net/25583515/viewspace-2685493/

AI

开发者交流群×