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多平台发布

相关推荐
AC赳赳老秦24 分钟前
OpenClaw任务复盘自动化:统计每日完成工作、遗留问题,优化工作节奏
java·大数据·linux·运维·服务器·数据库·openclaw
AOwhisky44 分钟前
学习自测(MySQL系列第一期、第二期)
linux·运维·数据库·学习·mysql·云计算
我叫张小白。1 小时前
Redis BitMap实现用户签到功能
数据库·redis·缓存·fastapi
大数据魔法师1 小时前
MongoDB(九) - MongoDB分片集安装与配置
数据库·mongodb
念何架构之路1 小时前
存储层技术MySQL
数据库·mysql
cfm_29141 小时前
Redis高并发多级缓存介绍 + JDHotkey热点探测了解
数据库·redis·缓存
yun呐1 小时前
mysql数据库误删恢复
数据库·mysql·adb
IvorySQL1 小时前
PostgreSQL 技术日报 (6月3日)|复制日志补丁更新,PG 黑客坊开启
数据库·人工智能·postgresql
j7~1 小时前
【MYSQL】图形化界面使用说明-- MYSQL(workbench)
数据库·mysql·mysql图形化界面·mysqlworkbench
m0_653031362 小时前
(文档)第124讲:异构数据库同步利器 — SynchDB使用全攻略
数据库