对数据库 ACID中的一致性Consistency的理解

查看mysql官方文档:

Consistency:

The consistency aspect of the ACID model mainly involves internal InnoDB processing to protect data from crashes. Related MySQL features include:

  • InnoDB doublewrite buffer.

  • InnoDB crash recovery

翻译过来就是:

一致性:
ACID模型的一致性方面主要涉及内部InnoDB处理以保护数据免于崩溃。 相关的MySQL功能包括:

InnoDB双写缓冲区。

InnoDB崩溃恢复

 

针对这个InnoDB双写缓冲区:

双写缓冲区
InnoDB使用名为doublewrite的文件刷新技术。 在将页面写入数据文件之前,InnoDB首先将它们写入称为doublewrite缓冲区的连续区域。 只有在完成对doublewrite缓冲区的写入和刷新之后,InnoDB才会将页面写入数据文件中的正确位置。 如果在页面写入过程中存在操作系统,存储子系统或mysqld进程崩溃,InnoDB稍后可以在崩溃恢复期间从doublewrite缓冲区中找到该页面的良好副本。

虽然数据总是写入两次,但双写缓冲区不需要两倍的I / O开销或两倍的I / O操作。 数据作为一个大的顺序块写入缓冲区本身,对操作系统进行单个fsync()调用。

你可能感兴趣的:(对数据库 ACID中的一致性Consistency的理解)