MySQL 的 Doublewrite Buffer 是什么?它有什么作用?
MySQL 的 Doublewrite Buffer 是什么?它有什么作用?
Doublewrite Buffer 是 InnoDB 存储引擎的一种机制,旨在提高数据的安全性,防止在写入磁盘时发生崩溃导致数据损坏。它通过将数据先写入内存中的一个缓冲区,再写入磁盘,从而确保数据一致性。
Doublewrite Buffer 的工作原理
数据写入过程:
- 在写入数据时,InnoDB 会将数据首先写入 Doublewrite Buffer。这个缓冲区位于 InnoDB 的系统表空间(system tablespace)中,通常是在内存中的一个特殊区域。
- 数据在写入 Doublewrite Buffer 后,InnoDB 会将其从该缓冲区写入实际的磁盘数据文件(即
.ibd
文件或表空间文件)。这个过程可以防止磁盘写入操作失败或崩溃时造成的数据损坏。
崩溃恢复机制:
- 如果数据库发生崩溃(如突然断电或系统崩溃),可能导致尚未完全写入磁盘的数据文件发生损坏。由于数据已经在 Doublewrite Buffer 中有一份完整的副本,InnoDB 在重启时可以使用这个副本进行恢复。
- Doublewrite Buffer 中的数据在写入磁盘时保证了原子性,这意味着即使在崩溃时,也不会有部分数据被写入,另一部分数据没有被写入的情况,从而防止了脏页和数据不一致的问题。
写入过程中的效率影响:
- 使用 Doublewrite Buffer 机制会带来一定的性能开销,因为每次写操作都需要经过两次写入(一次到缓冲区,第二次到磁盘)。
- 尽管如此,这种写入冗余是为保证数据的安全性而做出的折衷。
Doublewrite Buffer 的作用
防止数据损坏:
- Doublewrite Buffer 能有效防止磁盘写入时发生的故障造成数据损坏。即使系统崩溃,数据依然可以从 Doublewrite Buffer 中恢复。
保证数据一致性:
- 通过确保每次写操作的原子性,避免了部分数据写入成功、部分数据写入失败的情况,从而确保数据一致性。
提供崩溃恢复能力:
- 通过将写入操作先写入缓冲区,然后才写入磁盘,InnoDB 在数据库重启时能通过检查 Doublewrite Buffer 来恢复尚未完全写入磁盘的数据。
总结
- Doublewrite Buffer 是 InnoDB 提供的一种保护机制,用于保证数据写入过程中的安全性和一致性。
- 它通过将数据写入内存中的缓冲区,然后再写入磁盘,以此防止由于崩溃导致的数据损坏。
- 尽管它引入了一定的性能开销,但它大大提高了数据的可靠性和恢复能力,尤其是在系统崩溃后。
这种机制使得 MySQL 在面对硬件故障或系统崩溃时,能够在一定程度上恢复数据,确保数据库的可靠性和数据完整性。
MySQL 的 Doublewrite Buffer 是什么?它有什么作用?的更多相关文章
- MySQL Doublewrite Buffer及业务评估
1. 关于Doublewrite Buffe的总结 Doublewrite Buffer:Doublewrite Buffer出现的初衷是防止buffer pool中的脏页刷新到磁盘中,出现部分写的问 ...
- mysql 优化之 doublewrite buffer 机制
是什么? doublewrite buffer是mysql 系统表空间的一块存储区域. 有什么用? 在Innodb将数据页写到数据存储文件之前,存储从Innodb缓存池刷过来的数据页.且只有将数写入d ...
- InnoDB On-Disk Structures(四)--Doublewrite Buffer (转载)
转载.节选于 https://dev.mysql.com/doc/refman/8.0/en/innodb-doublewrite-buffer.html The doublewrite buffer ...
- php中mysql操作的buffer知识
php与mysql的连接有三种方式,mysql,mysqli,pdo.不管使用哪种方式进行连接,都有使用buffer和不使用buffer的区别. 什么叫使用buffer和不使用buffer呢? 客户端 ...
- mysql 原理 ~ change buffer
一 简介:今天咱们来聊聊mysql的change buffer二 详细说明 1 +-change Buffer和数据页一样,也是物理页的一个组成部分,数据结构也是一颗B+树,这棵B+树放在共享表空 ...
- MYSQL 优化--inner buffer 与关联查询变等值查询
转自:https://www.2cto.com/database/201312/262376.html 在数据库的应用中,我们经常需要对多表进行连表操作来获得关系型的数据,因此,应该更加的掌握好Mid ...
- 全网最清楚的:MySQL的insert buffer和change buffer 串讲
目录 一.前言 二.问题引入 2.1.聚簇索引 2.2.普通索引 三.change buffer存在的意义 四.再看change buffer 五.change buffer 的限制 六.change ...
- MySQL:change buffer
1. 概念 Innodb维护了一个缓存区域叫做Buffer Pool,用来缓存数据和索引在内存中.其大小通过参数 innodb_buffer_pool_size 控制: change buffer 是 ...
- mysql 连接url中useUnicode=true&characterEncoding=UTF-8 的作用
添加的作用是:指定字符的编码.解码格式. 例如:mysql数据库用的是gbk编码,而项目数据库用的是utf-8编码.这时候如果添加了useUnicode=true&cha ...
- MySQL的BlackHole引擎在主从架构中的作用
MySQL在5.x系列提供了Blackhole引擎–“黑洞”. 其作用正如其名字一样:任何写入到此引擎的数据均会被丢弃掉, 不做实际存储:Select语句的内容永远是空. 和Linux中的 /dev/ ...
随机推荐
- 详细剖析Java动态线程池的扩容以及缩容操作
前言 在项目中,我们经常会使用到线程来处理加快我们的任务.但为了节约资源,大多数程序员都会把线程进行池化,使用线程池来更好的支持我们的业务. Java线程池ThreadPoolExecutor有几个比 ...
- 所生成项目的处理器架构“MSIL”与 “x86”不匹配
在 .net 生成时如果修改过某个类库的平台目标,那么通常会出现下面的警告: 之所以产生这个问题是因为类库的"平台目标"不统一,如果选择了 x86, 那么解决方案中所有的项目都应设 ...
- C# Dev GridView当前行
DEV获取GridControl当前行 //直接通过gridView获取当前行 dr=this.gridView1.GetDataRow(this.gridView1.FocusedRowHandle ...
- linux--notepad++安装
通过PPA进行安装notepad++ sudo add-apt-repository ppa:notepadqq-team/notepadqq sudo apt-get update sudo a ...
- 你的边比较松弛:最短路的 Bellman-Ford 和 SPFA 方法
Dijkstra 的局限性 在带权图的最短路径问题中,我们的目标是从一个起点出发,找到到达其他所有节点的最短路径.无论是交通导航中的最短耗时路线,还是金融网络中的最小成本路径,这一问题的核心始终是如何 ...
- 2025AI应用元年,DeepSeek让领域小模型训练成本急剧下降!
关注公众号回复1 获取一线.总监.高管<管理秘籍> 模型训练俗称炼丹,而炼丹是修士特权,这就显得模型训练离普通人很远了. 虽然是笑谈,但如果对其中情况不太了解确实也会因为其背后深厚.复杂的 ...
- 使用Visual Studio 调式NDK so 库时,调试工具无法显示vector内容
最近在研究C++开发安卓端so库,demo使用xamarin.android作为载体来验证算法库文件的准确性.调试过程中发现vector中的内容无法显示集合详细.如下图 研究了半天(参考链接2.3), ...
- Kafka - server.properties参数详解
server.properties #broker的全局唯一编号,不能重复 broker.id=0 #用来监听链接的端口(kafka端口号),producer或consumer将在此端口建立连接 po ...
- Week09_day05(Hbase的介绍和工作原理)
HBase是一个分布式的.面向列的开源数据库,该技术来源于 Fay Chang 所撰写的Google论文"Bigtable:一个结构化数据的分布式存储系统".就像Bigtable利 ...
- Vigenere密码无密钥求解
0.前言 最近摸了很长时间的鱼,然后最近突然想搞一个Vigenere密码的自动求解,花了不到一天来实现了一下这个东西,不过受限于自己的水平,没有搞的太难.当然,代码部分不是全部都是从 0 开始的,关于 ...