当前位置: 首页 > news >正文

深圳网站建设列表网北京专业制作网站

深圳网站建设列表网,北京专业制作网站,WordPress文字黑条,平面设计线本文已收录至Github#xff0c;推荐阅读 #x1f449; Java随想录 文章目录 摘要为什么需要Doublewrite BufferDoublewrite Buffer原理Doublewrite Buffer相关参数总结 摘要 InnoDB是MySQL中一种常用的事务性存储引擎#xff0c;它具有很多优秀的特性。其中#xff0c;Dou…本文已收录至Github推荐阅读 Java随想录 文章目录 摘要为什么需要Doublewrite BufferDoublewrite Buffer原理Doublewrite Buffer相关参数总结 摘要 InnoDB是MySQL中一种常用的事务性存储引擎它具有很多优秀的特性。其中Doublewrite Buffer是InnoDB的一个重要特性之一本文将介绍Doublewrite Buffer的原理和应用。 为什么需要Doublewrite Buffer 我们常见的服务器一般都是Linux操作系统Linux文件系统页OS Page的大小默认是4KB。而MySQL的页Page大小默认是16KB。 可以使用如下命令查看MySQL的Page大小 SHOW VARIABLES LIKE innodb_page_size;一般情况下其余程序因为需要跟操作系统交互它们的页Page都会大于等于操作系统的页大小为整数倍。比如Oracle的Page大小为8KB。 MySQL程序是跑在Linux操作系统上的需要跟操作系统交互所以MySQL中一页数据刷到磁盘要写4个文件系统里的页。 需要注意的是这个操作并非原子操作比如我操作系统写到第二个页的时候Linux机器断电了这时候就会出现问题了。造成”页数据损坏“。并且这种”页数据损坏“靠 redo日志是无法修复的。 重做日志中记录的是对页的物理操作而不是页面的全量记录而如果发生partial page write部分页写入问题时出现问题的是未修改过的数据此时重做日志(Redo Log)无能为力。写doublewrite buffer成功了这个问题就不用担心了。 Doublewrite Buffer的出现就是为了解决上面的这种情况虽然名字带了Buffer但实际上Doublewrite Buffer是内存磁盘的结构。 Doublewrite Buffer是一种特殊文件flush技术带给InnoDB存储引擎的是数据页的可靠性。它的作用是在把页写到数据文件之前InnoDB先把它们写到一个叫doublewrite buffer双写缓冲区的共享表空间内在写doublewrite buffer完成后InnoDB才会把页写到数据文件的适当的位置。如果在写页的过程中发生意外崩溃InnoDB在稍后的恢复过程中在doublewrite buffer中找到完好的page副本用于恢复。 Doublewrite Buffer原理 如上图所示当有页数据要刷盘时 页数据先通过memcpy函数拷贝至内存中的Doublewrite Buffer中 Doublewrite Buffer的内存里的数据页会fsync刷到Doublewrite Buffer的磁盘上分两次写入磁盘共享表空间中(连续存储顺序写性能很高)每次写1MB Doublewrite Buffer的内存里的数据页再刷到数据磁盘存储.ibd文件上离散写 Doublewrite Buffer内存结构由128个页Page构成大小是2MB。 Doublewrite Buffer磁盘结构在系统表空间上是128个页2个区extend1和extend2大小是2MB。 如果操作系统在将页写入磁盘的过程中发生了崩溃在恢复过程中InnoDB存储引擎可以从共享表空间中的Double write中找到该页的一个副本将其复制到表空间文件再应用重做日志。 MySQL会检查double writer的数据的完整性如果不完整直接丢弃double write buffer内容重新执行那条redo log如果double write buffer的数据是完整的用double writer buffer的数据更新该数据页跳过该redo log。 所以在正常的情况下MySQL写数据页时会写两遍到磁盘上第一遍是写到doublewrite buffer第二遍是写到真正的数据文件中这就是“Doublewrite”的由来。 在数据库异常关闭的情况下启动时都会做数据库恢复redo操作恢复的过程中数据库都会检查页面是不是合法校验等等如果发现一个页面校验结果不一致则此时会用到双写这个功能。 我们可以通过如下命令来监控Doublewrite Buffer工作负载 mysql show global status like %dblwr%;Doublewrite Buffer相关参数 innodb_doublewriteDoublewrite Buffer是否启用开关默认是开启状态InnoDB将所有数据存储两次首先到双写缓冲区然后到实际数据文件。Innodb_dblwr_pages_written记录写入到DWB中的页数量。Innodb_dblwr_writes记录DWB写操作的次数。 总结 InnoDB Doublewrite Buffer是InnoDB的一个重要特性用于保证MySQL数据的可靠性和一致性。它的实现原理是通过将要写入磁盘的数据先写入到Doublewrite Buffer中的内存缓存区域然后再写入到磁盘的两个不同位置来避免由于磁盘损坏等因素导致数据丢失或不一致的问题。Doublewrite Buffer对于保证MySQL数据的安全性和一致性具有重要意义。
http://www.hkea.cn/news/14414813/

相关文章:

  • 企业网站php四川建设厅网站怎么进不去
  • 长沙好的做网站品牌北京企业网站建设哪家服务好
  • 公司网站如何seo上海公司黄页网站
  • 网站规划与建设 试卷to a wordpress
  • 做电商网站用什么语言wordpress for sae
  • 大理装饰公司做网站现在做网站建设都是自建
  • 企业搭建网站多少钱郑州航空港建设局网站
  • 文化网站建设心得福建省建设工程资格中心网站
  • 怎么把自己的网站推广wordpress站点临时关闭
  • 做餐饮培训网站广告WordPress后端API
  • 餐馆效果图网站公众号怎么制作投票
  • 免费网站推广网站在线专业做网站建
  • 电子商务中的网站开发外包app公司不给源代码
  • 国内有什么网站网站建设理论依据
  • 一站建设个人网站乐清网站优化推广
  • 深圳网站建设 设计卓越迈建设网站最强
  • 网站手机版模板kratos wordpress
  • it行业公司排名企业站seo价格
  • 太原市网站建设开一家网站建设公司要多少钱
  • 中小型网站建设与管理总结WordPress纯代码添加
  • 竞价网站做seo北京网络公司建站
  • 浙江交通工程建设集团网站企业网站展示论文
  • 酒店房产网站建设如何写网站建设方案
  • 百度关键词搜索排行榜盐城优化办
  • 网站做影集安全吗网站建设柚子网络科技在哪里
  • 如何制作一个单页网站盐城快速建设网站找哪家
  • 迅驰互联网站建设网络推广怎么样企业微信管理
  • 廊坊集团网站建设沈阳自主建站模板
  • 虚拟机做网站有用吗windows+wordpress+mi
  • 网站模板下载百度云链接怎么做的学包装设计网站