从品牌网站建设到网络营销策划,从策略到执行的一站式服务
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不完整写时就没有地方可恢复的了。
附图:
看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注创新互联-成都网站建设公司行业资讯频道,感谢您对创新互联的支持。
成都网站建设公司地址:成都市青羊区太升南路288号锦天国际A座10层 建设咨询028-86922220
成都快上网科技有限公司-四川网站建设设计公司 | 蜀ICP备19037934号 Copyright 2020,ALL Rights Reserved cdkjz.cn | 成都网站建设 | © Copyright 2020版权所有.
专家团队为您提供成都网站建设,成都网站设计,成都品牌网站设计,成都营销型网站制作等服务,成都建网站就找快上网! | 成都网站建设哪家好? | 网站建设地图