您的位置:首页 > Web前端

InnoDB On-Disk Structures(四)--Doublewrite Buffer (转载)

2019-08-21 10:40 85 查看

转载、节选于 https://dev.mysql.com/doc/refman/8.0/en/innodb-doublewrite-buffer.html

 

The doublewrite buffer is a storage area located in the system tablespace where 

InnoDB
 writes pages that are flushed from the 
InnoDB
 buffer pool, before the pages are written to their proper positions in the data file. Only after flushing and writing pages to the doublewrite buffer, does 
InnoDB
 write pages to their proper positions. If there is an operating system, storage subsystem, or mysqld process crash in the middle of a page write, 
InnoDB
 can later find a good copy of the page from the doublewrite buffer during crash recovery.

Although data is always written twice, the doublewrite buffer does not require twice as much I/O overhead or twice as many I/O operations. Data is written to the doublewrite buffer itself as a large sequential chunk, with a single 

fsync()
 call to the operating system.

The doublewrite buffer is enabled by default in most cases. To disable the doublewrite buffer, set 

innodb_doublewrite
 to 0.

If system tablespace files (“ibdata files”) are located on Fusion-io devices that support atomic writes, doublewrite buffering is automatically disabled and Fusion-io atomic writes are used for all data files. Because the doublewrite buffer setting is global, doublewrite buffering is also disabled for data files residing on non-Fusion-io hardware. This feature is only supported on Fusion-io hardware and is only enabled for Fusion-io NVMFS on Linux. To take full advantage of this feature, an 

innodb_flush_method
setting of 
O_DIRECT
 is recommended.

 

转载、节选于 https://dev.mysql.com/doc/refman/8.0/en/innodb-doublewrite-buffer.html

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: