The doublewrite buffer is a storage area where
      InnoDB writes pages flushed from the buffer
      pool before writing the pages to their proper positions in the
      InnoDB data files. If there is an operating
      system, storage subsystem, or unexpected mysqld
      process exit in the middle of a page write,
      InnoDB can find a good copy of the page from
      the doublewrite buffer during crash recovery.
    
      Although data is 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 in a large
      sequential chunk, with a single fsync() call to
      the operating system (except in the case that
      innodb_flush_method is set to
      O_DIRECT_NO_FSYNC).
    
The doublewrite buffer storage area is located in doublewrite files.
The following variables are provided for doublewrite buffer configuration:
- The - innodb_doublewritevariable controls whether the doublewrite buffer is enabled. It is enabled by default in most cases. To disable the doublewrite buffer, set- innodb_doublewriteto- OFF. Consider disabling the doublewrite buffer if you are more concerned with performance than data integrity, as may be the case when performing benchmarks, for example.- innodb_doublewritesupports- DETECT_AND_RECOVERand- DETECT_ONLYsettings.- The - DETECT_AND_RECOVERsetting is the same as the- ONsetting. With this setting, the doublewrite buffer is fully enabled, with database page content written to the doublewrite buffer where it is accessed during recovery to fix incomplete page writes.- With the - DETECT_ONLYsetting, only metadata is written to the doublewrite buffer. Database page content is not written to the doublewrite buffer, and recovery does not use the doublewrite buffer to fix incomplete page writes. This lightweight setting is intended for detecting incomplete page writes only.- MySQL supports dynamic changes to the - innodb_doublewritesetting that enables the doublewrite buffer, between- ON,- DETECT_AND_RECOVER, and- DETECT_ONLY. MySQL does not support dynamic changes between a setting that enables the doublewrite buffer and- OFFor vice versa.- If the doublewrite buffer is located on a Fusion-io device that supports atomic writes, the doublewrite buffer is automatically disabled and data file writes are performed using Fusion-io atomic writes instead. However, be aware that the - innodb_doublewritesetting is global. When the doublewrite buffer is disabled, it is disabled for all data files including those that do not reside on 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_methodsetting of- O_DIRECTis recommended.
- The - innodb_doublewrite_dirvariable defines the directory where- InnoDBcreates doublewrite files. If no directory is specified, doublewrite files are created in the- innodb_data_home_dirdirectory, which defaults to the data directory if unspecified.- A hash symbol '#' is automatically prefixed to the specified directory name to avoid conflicts with schema names. However, if a '.', '#'. or '/' prefix is specified explicitly in the directory name, the hash symbol '#' is not prefixed to the directory name. - Ideally, the doublewrite directory should be placed on the fastest storage media available. 
- The - innodb_doublewrite_filesvariable defines the number of doublewrite files, which defaults to 2. By default, two doublewrite files are created for each buffer pool instance: A flush list doublewrite file and an LRU list doublewrite file.- The flush list doublewrite file is for pages flushed from the buffer pool flush list. The default size of a flush list doublewrite file is the - InnoDBpage size * doublewrite page bytes.- The LRU list doublewrite file is for pages flushed from the buffer pool LRU list. It also contains slots for single page flushes. The default size of an LRU list doublewrite file is the - InnoDBpage size * (doublewrite pages + (512 / the number of buffer pool instances)) where 512 is the total number of slots reserved for single page flushes.- At a minimum, there are two doublewrite files. The maximum number of doublewrite files is two times the number of buffer pool instances. (The number of buffer pool instances is controlled by the - innodb_buffer_pool_instancesvariable.)- Doublewrite file names have the following format: - #ib_(or- page_size_- file_number.dblwr- .bdblwrwith the- DETECT_ONLYsetting). For example, the following doublewrite files are created for a MySQL instance with an- InnoDBpages size of 16KB and a single buffer pool:- #ib_16384_0.dblwr #ib_16384_1.dblwr- The - innodb_doublewrite_filesvariable is intended for advanced performance tuning. The default setting should be suitable for most users.
- The - innodb_doublewrite_pagesvariable controls the maximum number of doublewrite pages per thread. This variable is intended for advanced performance tuning. The default value should be suitable for most users.
      InnoDB automatically encrypts doublewrite file
      pages that belong to encrypted tablespaces (see
      Section 17.13, “InnoDB Data-at-Rest Encryption”). Likewise, doublewrite
      file pages belonging to page-compressed tablespaces are
      compressed. As a result, doublewrite files can contain different
      page types including unencrypted and uncompressed pages, encrypted
      pages, compressed pages, and pages that are both encrypted and
      compressed.