MySQL双写机制

双写机制

问题的出现

在发生数据库宕机时,可能Innodb正在写入某个页到表中,但是这个页只写了一部分,这种情况被称为部分写失效,虽然innodb会先写重做日志,在修改页,但是重做日志中记录的是对页的物理操作,但是如果这个页本身已经发生了损坏,对页进行重做是没有意义的

双写的出现

为了解决这个问题,提出了双写机制

双写原理

双写(doublewrite)由两部分组成,一部分是内存中的doublewrite buffer,大小为2M,另一部分是屋里磁盘上共享表空间中连续的128个页,大小也是2M。再对缓冲池中的脏页进行刷新时,并不直接写磁盘,而是会通过memcpy函数将脏页复制到内存中的doublewrite buffer,之后通过doublewrite buffer再分两次,每次1M顺序地写入共享表空间的物理磁盘上,然后马上调用fync函数,同步磁盘,避免缓冲写带来的问题

sql 复制代码
-- 查看doublewrite的运行情况
show global status like 'innodb_db%' \G
*************************** 1. row ***************************
Variable_name: Innodb_dblwr_pages_written  双写页数
        Value: 98848391
*************************** 2. row ***************************
Variable_name: Innodb_dblwr_writes  写入次数
        Value: 9607931

zhhll.icu/2021/数据库/关系...

本文由mdnice多平台发布

相关推荐
e***193529 分钟前
【SqlServer】SQL Server Management Studio (SSMS) 下载、安装、配置使用及卸载——保姆级教程
数据库·sqlserver
6***B4830 分钟前
存储过程(SQL)
android·数据库·sql
小马爱打代码1 小时前
避坑指南:MySQL 迁移到 TiDB
数据库·mysql·tidb
一个天蝎座 白勺 程序猿2 小时前
Apache IoTDB(10):数据库操作——从查询到优化的全链路实践指南
数据库·apache·时序数据库·iotdb
普普通通的南瓜2 小时前
IP证书在关键信息基础设施安全防护中的实践与挑战
网络·数据库·网络协议·tcp/ip·安全·ssl
合作小小程序员小小店2 小时前
桌面开发,超市管理系统开发,基于C#,winform,sql server数据库
开发语言·数据库·sql·microsoft·sqlserver·c#
quweiie2 小时前
thinkphp8.0链接SQL SERVER2022数据库
数据库·sqlserver·thinkphp
Databend3 小时前
如何打造AI时代的数据基石 | Databend Meetup 上海站
数据库
老华带你飞3 小时前
海产品销售系统|海鲜商城购物|基于SprinBoot+vue的海鲜商城系统(源码+数据库+文档)
java·前端·数据库·vue.js·论文·毕设·海鲜商城购物系统
合作小小程序员小小店4 小时前
桌面开发,在线%超市销售管理%系统,基于vs2022,c#,winform,sql server数据
开发语言·数据库·microsoft·c#