InnoDB On-Disk Structures(三)--Tablespaces (转载)
转载、节选于 https://dev.mysql.com/doc/refman/8.0/en/innodb-tablespace.html
This section covers topics related to InnoDB tablespaces.
1.The System Tablespace
The InnoDB system tablespace is the storage area for the doublewrite buffer and the change buffer. The system tablespace also contains table and index data for user-created tables created in the system tablespace. In previous releases, the system tablespace contained the InnoDB data dictionary. In MySQL 8.0, InnoDB stores metadata in the MySQL data dictionary.
The system tablespace can have one or more data files. By default, one system tablespace data file, named ibdata1, is created in the data directory. The size and number of system tablespace data files is controlled by the innodb_data_file_path startup option.
Resizing the System Tablespace
This section describes how to increase or decrease the size of the InnoDB system tablespace.
Increasing the Size of the InnoDB System Tablespace
The easiest way to increase the size of the InnoDB system tablespace is to configure it from the beginning to be auto-extending. Specify the autoextend attribute for the last data file in the tablespace definition. Then InnoDB increases the size of that file automatically in 64MB increments when it runs out of space. The increment size can be changed by setting the value of the innodb_autoextend_increment system variable, which is measured in megabytes.
You can expand the system tablespace by a defined amount by adding another data file:
- Shut down the MySQL server. 
- If the previous last data file is defined with the keyword - autoextend, change its definition to use a fixed size, based on how large it has actually grown. Check the size of the data file, round it down to the closest multiple of 1024 × 1024 bytes (= 1MB), and specify this rounded size explicitly in- innodb_data_file_path.
- Add a new data file to the end of - innodb_data_file_path, optionally making that file auto-extending. Only the last data file in the- innodb_data_file_pathcan be specified as auto-extending.
- Start the MySQL server again. 
For example, this tablespace has just one auto-extending data file ibdata1:
innodb_data_home_dir =
innodb_data_file_path = /ibdata/ibdata1:10M:autoextend
Suppose that this data file, over time, has grown to 988MB. Here is the configuration line after modifying the original data file to use a fixed size and adding a new auto-extending data file:
innodb_data_home_dir =
innodb_data_file_path = /ibdata/ibdata1:988M;/disk2/ibdata2:50M:autoextend
When you add a new data file to the system tablespace configuration, make sure that the filename does not refer to an existing file. InnoDB creates and initializes the file when you restart the server.
Decreasing the Size of the InnoDB System Tablespace
You cannot remove a data file from the system tablespace. To decrease the system tablespace size, use this procedure:
1.Use mysqldump to dump all your InnoDB tables, including InnoDB tables located in the MySQL database.
mysql> SELECT TABLE_NAME from INFORMATION_SCHEMA.TABLES WHERE TABLE_SCHEMA='mysql' and ENGINE='InnoDB';
+---------------------------+
| TABLE_NAME |
+---------------------------+
| columns_priv |
| component |
| db |
| default_roles |
| engine_cost |
| func |
| global_grants |
| gtid_executed |
| help_category |
| help_keyword |
| help_relation |
| help_topic |
| innodb_dynamic_metadata |
| innodb_index_stats |
| innodb_table_stats |
| plugin |
| procs_priv |
| proxies_priv |
| role_edges |
| server_cost |
| servers |
| slave_master_info |
| slave_relay_log_info |
| slave_worker_info |
| tables_priv |
| time_zone |
| time_zone_leap_second |
| time_zone_name |
| time_zone_transition |
| time_zone_transition_type |
| user |
+---------------------------+
2.Stop the server.
3.Remove all the existing tablespace files (*.ibd), including the ibdata and ib_log files. Do not forget to remove *.ibd files for tables located in the MySQL database.
4.Configure a new tablespace.
5.Restart the server.
6.Import the dump files.
注意:If your databases only use the InnoDB engine, it may be simpler to dump all databases, stop the server, remove all databases and InnoDB log files, restart the server, and import the dump files.
Using Raw Disk Partitions for the System Tablespace
You can use raw disk partitions as data files in the InnoDB system tablespace. This technique enables nonbuffered I/O on Windows and on some Linux and Unix systems without file system overhead. Perform tests with and without raw partitions to verify whether this change actually improves performance on your system.
When you use a raw disk partition, ensure that the user ID that runs the MySQL server has read and write privileges for that partition. For example, if you run the server as the mysql user, the partition must be readable and writeable by mysql. If you run the server with the --memlock option, the server must be run as root, so the partition must be readable and writeable by root.
The procedures described below involve option file modification.
Allocating a Raw Disk Partition on Linux and Unix Systems
- When you create a new data file, specify the keyword - newrawimmediately after the data file size for the- innodb_data_file_pathoption. The partition must be at least as large as the size that you specify. Note that 1MB in- InnoDBis 1024 × 1024 bytes, whereas 1MB in disk specifications usually means 1,000,000 bytes.- [mysqld] 
 innodb_data_home_dir=
 innodb_data_file_path=/dev/hdd1:3Gnewraw;/dev/hdd2:2Gnewraw
- Restart the server. - InnoDBnotices the- newrawkeyword and initializes the new partition. However, do not create or change any- InnoDBtables yet. Otherwise, when you next restart the server,- InnoDBreinitializes the partition and your changes are lost. (As a safety measure- InnoDBprevents users from modifying data when any partition with- newrawis specified.)
- After - InnoDBhas initialized the new partition, stop the server, change- newrawin the data file specification to- raw:- [mysqld] 
 innodb_data_home_dir=
 innodb_data_file_path=/dev/hdd1:3Graw;/dev/hdd2:2Graw
- Restart the server. - InnoDBnow permits changes to be made.
Allocating a Raw Disk Partition on Windows
On Windows systems, the same steps and accompanying guidelines described for Linux and Unix systems apply except that the innodb_data_file_path setting differs slightly on Windows.
- When you create a new data file, specify the keyword - newrawimmediately after the data file size for the- innodb_data_file_pathoption:- [mysqld] 
 innodb_data_home_dir=
 innodb_data_file_path=//./D::10Gnewraw- The - //./corresponds to the Windows syntax of- \\.\for accessing physical drives. In the example above,- D:is the drive letter of the partition.
- Restart the server. - InnoDBnotices the- newrawkeyword and initializes the new partition.
- After - InnoDBhas initialized the new partition, stop the server, change- newrawin the data file specification to- raw:- [mysqld] 
 innodb_data_home_dir=
 innodb_data_file_path=//./D::10Graw
- Restart the server. - InnoDBnow permits changes to be made.
2.File-Per-Table Tablespaces
Historically, InnoDB tables were stored in the system tablespace. This monolithic approach was targeted at machines dedicated to database processing, with carefully planned data growth, where any disk storage allocated to MySQL would never be needed for other purposes. The file-per-table tablespace feature provides a more flexible alternative, where each InnoDB table is stored in its own tablespace data file (.ibd file). This feature is controlled by the innodb_file_per_table configuration option, which is enabled by default.
Advantages
- You can reclaim disk space when truncating or dropping a table stored in a file-per-table tablespace. Truncating or dropping tables stored in the shared system tablespace creates free space internally in the system tablespace data files (ibdata files) which can only be used for new - InnoDBdata.- Similarly, a table-copying - ALTER TABLEoperation on table that resides in a shared tablespace can increase the amount of space used by the tablespace. Such operations may require as much additional space as the data in the table plus indexes. The additional space required for the table-copying- ALTER TABLEoperation is not released back to the operating system as it is for file-per-table tablespaces.
- The - TRUNCATE TABLEoperation is faster when run on tables stored in file-per-table tablespaces.
- You can store specific tables on separate storage devices, for I/O optimization, space management, or backup purposes by specifying the location of each table using the syntax - CREATE TABLE ... DATA DIRECTORY =- absolute_path_to_directory.
- You can run - OPTIMIZE TABLEto compact or recreate a file-per-table tablespace. When you run an- OPTIMIZE TABLE,- InnoDBcreates a new- .ibdfile with a temporary name, using only the space required to store actual data. When the optimization is complete,- InnoDBremoves the old- .ibdfile and replaces it with the new one. If the previous- .ibdfile grew significantly but the actual data only accounted for a portion of its size, running- OPTIMIZE TABLEcan reclaim the unused space.
- You can move individual - InnoDBtables rather than entire databases.
- You can copy individual - InnoDBtables from one MySQL instance to another (known as the transportable tablespace feature).
- Tables created in file-per-table tablespaces support features associated with compressed and dynamic row formats. 
- You can enable more efficient storage for tables with large - BLOBor- TEXTcolumns using the dynamic row format.
- File-per-table tablespaces may improve chances for a successful recovery and save time when a corruption occurs, when a server cannot be restarted, or when backup and binary logs are unavailable. 
- You can back up or restore individual tables quickly using the MySQL Enterprise Backup product, without interrupting the use of other - InnoDBtables. This is beneficial if you have tables that require backup less frequently or on a different backup schedule. See Making a Partial Backup for details.
- File-per-table tablespaces are convenient for per-table status reporting when copying or backing up tables. 
- You can monitor table size at a file system level without accessing MySQL. 
- Common Linux file systems do not permit concurrent writes to a single file when - innodb_flush_methodis set to- O_DIRECT. As a result, there are possible performance improvements when using file-per-table tablespaces in conjunction with- innodb_flush_method.
- The system tablespace stores the data dictionary and undo logs, and is limited in size by - InnoDBtablespace size limits. With file-per-table tablespaces, each table has its own tablespace, which provides room for growth.
Potential Disadvantages
- With file-per-table tablespaces, each table may have unused space, which can only be utilized by rows of the same table. This could lead to wasted space if not properly managed. 
- fsyncoperations must run on each open table rather than on a single file. Because there is a separate- fsyncoperation for each file, write operations on multiple tables cannot be combined into a single I/O operation. This may require- InnoDBto perform a higher total number of- fsyncoperations.
- mysqld must keep one open file handle per table, which may impact performance if you have numerous tables in file-per-table tablespaces. 
- More file descriptors are used. 
- innodb_file_per_tableis enabled by default in MySQL 5.6 and higher. You may consider disabling it if backward compatibility with earlier versions of MySQL is a concern.
- If many tables are growing there is potential for more fragmentation which can impede - DROP TABLEand table scan performance. However, when fragmentation is managed, having files in their own tablespace can improve performance.
- The buffer pool is scanned when dropping a file-per-table tablespace, which can take several seconds for buffer pools that are tens of gigabytes in size. The scan is performed with a broad internal lock, which may delay other operations. Tables in the system tablespace are not affected. 
- The - innodb_autoextend_incrementvariable, which defines increment size (in MB) for extending the size of an auto-extending shared tablespace file when it becomes full, does not apply to file-per-table tablespace files, which are auto-extending regardless of the- innodb_autoextend_incrementsetting. The initial extensions are by small amounts, after which extensions occur in increments of 4MB.
Enabling File-Per-Table Tablespaces
The innodb_file_per_table option is enabled by default.
You can also set innodb_file_per_table dynamically, while the server is running:
mysql> SET GLOBAL innodb_file_per_table=1;
With innodb_file_per_table enabled, you can store InnoDB tables in a tbl_name.ibdMyISAM storage engine, with its separate tbl_name.MYDtbl_name.MYIInnoDB stores the data and the indexes together in a single .ibd file.
If you disable innodb_file_per_table in your startup options and restart the server, or disable it with the SET GLOBAL command, InnoDB creates new tables inside the system tablespace unless you have explicitly placed the table in file-per-table tablespace or general tablespace using the CREATE TABLE ... TABLESPACE option.
You can always read and write any InnoDB tables, regardless of the file-per-table setting.
To move a table from the system tablespace to its own tablespace, change the innodb_file_per_table setting and rebuild the table:
mysql> SET GLOBAL innodb_file_per_table=1;
mysql> ALTER TABLE table_name ENGINE=InnoDB;
Tables added to the system tablespace using CREATE TABLE ... TABLESPACE or ALTER TABLE ... TABLESPACE syntax are not affected by the innodb_file_per_tablesetting. To move these tables from the system tablespace to a file-per-table tablespace, they must be moved explicitly using ALTER TABLE ... TABLESPACE syntax.
注意:
InnoDB always needs the system tablespace because it puts its internal data dictionary and undo logs there. The .ibd files are not sufficient forInnoDB to operate.
When a table is moved out of the system tablespace into its own .ibd file, the data files that make up the system tablespace remain the same size. The space formerly occupied by the table can be reused for new InnoDB data, but is not reclaimed for use by the operating system. When moving largeInnoDB tables out of the system tablespace, where disk space is limited, you may prefer to enable innodb_file_per_table and recreate the entire instance using the mysqldump command. As mentioned above, tables added to the system tablespace using CREATE TABLE ... TABLESPACE orALTER TABLE ... TABLESPACE syntax are not affected by the innodb_file_per_table setting. These tables must be moved individually.
3.General Tablespaces
A general tablespace is a shared InnoDB tablespace that is created using CREATE TABLESPACE syntax. General tablespace capabilities and features are described under the following topics in this section.
General Tablespace Capabilities
The general tablespace feature provides the following capabilities:
- Similar to the system tablespace, general tablespaces are shared tablespaces that can store data for multiple tables. 
- General tablespaces have a potential memory advantage over file-per-table tablespaces. The server keeps tablespace metadata in memory for the lifetime of a tablespace. Multiple tables in fewer general tablespaces consume less memory for tablespace metadata than the same number of tables in separate file-per-table tablespaces. 
- General tablespace data files may be placed in a directory relative to or independent of the MySQL data directory, which provides you with many of the data file and storage management capabilities of file-per-table tablespaces. As with file-per-table tablespaces, the ability to place data files outside of the MySQL data directory allows you to manage performance of critical tables separately, setup RAID or DRBD for specific tables, or bind tables to particular disks, for example. 
- General tablespaces support both Antelope and Barracuda file formats, and therefore support all table row formats and associated features. With support for both file formats, general tablespaces have no dependence on - innodb_file_formator- innodb_file_per_tablesettings, nor do these variables have any effect on general tablespaces.
- The - TABLESPACEoption can be used with- CREATE TABLEto create tables in a general tablespaces, file-per-table tablespace, or in the system tablespace.
- The - TABLESPACEoption can be used with- ALTER TABLEto move tables between general tablespaces, file-per-table tablespaces, and the system tablespace. Previously, it was not possible to move a table from a file-per-table tablespace to the system tablespace. With the general tablespace feature, you can now do so.
Creating a General Tablespace
General tablespaces are created using CREATE TABLESPACE syntax.
CREATE TABLESPACE tablespace_name
[ADD DATAFILE 'file_name']
[FILE_BLOCK_SIZE = value]
[ENGINE [=] engine_name]
A general tablespace can be created in the data directory or outside of it. To avoid conflicts with implicitly created file-per-table tablespaces, creating a general tablespace in a subdirectory under the data directory is not supported. When creating a general tablespace outside of the data directory, the directory must exist and must be known toInnoDB prior to creating the tablespace. To make an unknown directory known to InnoDB, add the directory to the innodb_directories argument value. innodb_directories is a read-only startup option. Configuring it requires restarting the server.
Examples:
Creating a general tablespace in the data directory:
mysql> CREATE TABLESPACE `ts1` ADD DATAFILE 'ts1.ibd' Engine=InnoDB;
or
mysql> CREATE TABLESPACE `ts1` Engine=InnoDB;
The ADD DATAFILE clause is optional as of MySQL 8.0.14 and required before that. If the ADD DATAFILE clause is not specified when creating a tablespace, a tablespace data file with a unique file name is created implicitly. The unique file name is a 128 bit UUID formatted into five groups of hexadecimal numbers separated by dashes (aaaaaaaa-bbbb-cccc-dddd-eeeeeeeeeeee). General tablespace data files include an .ibd file extension. In a replication environment, the data file name created on the master is not the same as the data file name created on the slave.
Creating a general tablespace in a directory outside of the data directory:
mysql> CREATE TABLESPACE `ts1` ADD DATAFILE '/my/tablespace/directory/ts1.ibd' Engine=InnoDB;
You can specify a path that is relative to the data directory as long as the tablespace directory is not under the data directory. In this example, the my_tablespace directory is at the same level as the data directory:
mysql> CREATE TABLESPACE `ts1` ADD DATAFILE '../my_tablespace/ts1.ibd' Engine=InnoDB;
注意:The ENGINE = InnoDB clause must be defined as part of the CREATE TABLESPACE statement, or InnoDB must be defined as the default storage engine (default_storage_engine=InnoDB).
Adding Tables to a General Tablespace
After creating an InnoDB general tablespace, you can use CREATE TABLE  or tbl_name ... TABLESPACE [=] tablespace_nameALTER TABLE  to add tables to the tablespace, as shown in the following examples:tbl_name TABLESPACE [=]tablespace_name
CREATE TABLE:
mysql> CREATE TABLE t1 (c1 INT PRIMARY KEY) TABLESPACE ts1;
ALTER TABLE:
mysql> ALTER TABLE t2 TABLESPACE ts1;
注意:Support for adding table partitions to shared tablespaces was deprecated in MySQL 5.7.24 and removed in MySQL 8.0.13. Shared tablespaces include the InnoDB system tablespace and general tablespaces.
General Tablespace Row Format Support
General tablespaces support all table row formats (REDUNDANT, COMPACT, DYNAMIC, COMPRESSED) with the caveat that compressed and uncompressed tables cannot coexist in the same general tablespace due to different physical page sizes.
For a general tablespace to contain compressed tables (ROW_FORMAT=COMPRESSED), FILE_BLOCK_SIZE must be specified, and the FILE_BLOCK_SIZE value must be a valid compressed page size in relation to the innodb_page_size value. Also, the physical page size of the compressed table (KEY_BLOCK_SIZE) must be equal toFILE_BLOCK_SIZE/1024. For example, if innodb_page_size=16KB and FILE_BLOCK_SIZE=8K, the KEY_BLOCK_SIZE of the table must be 8.
The following table shows permitted innodb_page_size, FILE_BLOCK_SIZE, and KEY_BLOCK_SIZE combinations. FILE_BLOCK_SIZE values may also be specified in bytes. To determine a valid KEY_BLOCK_SIZE value for a given FILE_BLOCK_SIZE, divide the FILE_BLOCK_SIZE value by 1024. Table compression is not support for 32K and 64KInnoDB page sizes.
Permitted Page Size, FILE_BLOCK_SIZE, and KEY_BLOCK_SIZE Combinations for Compressed Tables
| InnoDB Page Size (innodb_page_size) | Permitted FILE_BLOCK_SIZE Value | Permitted KEY_BLOCK_SIZE Value | 
|---|---|---|
| 64KB | 64K (65536) | Compression is not supported | 
| 32KB | 32K (32768) | Compression is not supported | 
| 16KB | 16K (16384) | N/A: If innodb_page_sizeis equal toFILE_BLOCK_SIZE, the tablespace cannot contain a compressed table. | 
| 16KB | 8K (8192) | 8 | 
| 16KB | 4K (4096) | 4 | 
| 16KB | 2K (2048) | 2 | 
| 16KB | 1K (1024) | 1 | 
| 8KB | 8K (8192) | N/A: If innodb_page_sizeis equal toFILE_BLOCK_SIZE, the tablespace cannot contain a compressed table. | 
| 8KB | 4K (4096) | 4 | 
| 8KB | 2K (2048) | 2 | 
| 8KB | 1K (1024) | 1 | 
| 4KB | 4K (4096) | N/A: If innodb_page_sizeis equal toFILE_BLOCK_SIZE, the tablespace cannot contain a compressed table. | 
| 4KB | 2K (2048) | 2 | 
| 4KB | 1K (1024) | 1 | 
This example demonstrates creating a general tablespace and adding a compressed table. The example assumes a default innodb_page_size of 16KB. TheFILE_BLOCK_SIZE of 8192 requires that the compressed table have a KEY_BLOCK_SIZE of 8.
mysql> CREATE TABLESPACE `ts2` ADD DATAFILE 'ts2.ibd' FILE_BLOCK_SIZE = 8192 Engine=InnoDB; mysql> CREATE TABLE t4 (c1 INT PRIMARY KEY) TABLESPACE ts2 ROW_FORMAT=COMPRESSED KEY_BLOCK_SIZE=8;
If you do not specify FILE_BLOCK_SIZE when creating a general tablespace, FILE_BLOCK_SIZE defaults to innodb_page_size. When FILE_BLOCK_SIZE is equal toinnodb_page_size, the tablespace may only contain tables with an uncompressed row format (COMPACT, REDUNDANT, and DYNAMIC row formats).
Moving Tables Between Tablespaces Using ALTER TABLE
You can use ALTER TABLE with the TABLESPACE option to move a table to an existing general tablespace, to a new file-per-table tablespace, or to the system tablespace.
注意:Support for placing table partitions in shared tablespaces was deprecated in MySQL 5.7.24 and removed MySQL 8.0.13. Shared tablespaces include the InnoDB system tablespace and general tablespace.
To move a table from a file-per-table tablespace or from the system tablespace to a general tablespace, specify the name of the general tablespace. The general tablespace must exist.
ALTER TABLE tbl_name TABLESPACE [=] tablespace_name;
To move a table from a general tablespace or file-per-table tablespace to the system tablespace, specify innodb_system as the tablespace name.
ALTER TABLE tbl_name TABLESPACE [=] innodb_system;
To move a table from the system tablespace or a general tablespace to a file-per-table tablespace, specify innodb_file_per_table as the tablespace name.
ALTER TABLE tbl_name TABLESPACE [=] innodb_file_per_table;
ALTER TABLE ... TABLESPACE operations always cause a full table rebuild, even if the TABLESPACE attribute has not changed from its previous value.
ALTER TABLE ... TABLESPACE syntax does not support moving a table from a temporary tablespace to a persistent tablespace.
The DATA DIRECTORY clause is permitted with CREATE TABLE ... TABLESPACE=innodb_file_per_table but is otherwise not supported for use in combination with theTABLESPACE option.
Restrictions apply when moving tables from encrypted tablespaces.
Dropping a General Tablespace
The DROP TABLESPACE statement is used to drop an InnoDB general tablespace.
All tables must be dropped from the tablespace prior to a DROP TABLESPACE operation. If the tablespace is not empty, DROP TABLESPACE returns an error.
Use a query similar to the following to identify tables in a general tablespace.
mysql> SELECT a.NAME AS space_name, b.NAME AS table_name FROM INFORMATION_SCHEMA.INNODB_TABLESPACES a,
INFORMATION_SCHEMA.INNODB_TABLES b WHERE a.SPACE=b.SPACE AND a.NAME LIKE 'ts1';
+------------+------------+
| space_name | table_name |
+------------+------------+
| ts1 | test/t1 |
| ts1 | test/t2 |
| ts1 | test/t3 |
+------------+------------+
A general InnoDB tablespace is not deleted automatically when the last table in the tablespace is dropped. The tablespace must be dropped explicitly using DROP TABLESPACE .tablespace_name
A general tablespace does not belong to any particular database. A DROP DATABASE operation can drop tables that belong to a general tablespace but it cannot drop the tablespace, even if the DROP DATABASE operation drops all tables that belong to the tablespace. A general tablespace must be dropped explicitly using DROP TABLESPACE.tablespace_name
Similar to the system tablespace, truncating or dropping tables stored in a general tablespace creates free space internally in the general tablespace .ibd data file which can only be used for new InnoDB data. Space is not released back to the operating system as it is when a file-per-table tablespace is deleted during a DROP TABLE operation.
This example demonstrates how to drop an InnoDB general tablespace. The general tablespace ts1 is created with a single table. The table must be dropped before dropping the tablespace.
mysql> CREATE TABLESPACE `ts1` ADD DATAFILE 'ts1.ibd' Engine=InnoDB; mysql> CREATE TABLE t1 (c1 INT PRIMARY KEY) TABLESPACE ts10 Engine=InnoDB; mysql> DROP TABLE t1; mysql> DROP TABLESPACE ts1;
注意:tablespace_name
General Tablespace Limitations
- A generated or existing tablespace cannot be changed to a general tablespace. 
- Creation of temporary general tablespaces is not supported. 
- General tablespaces do not support temporary tables. 
- Similar to the system tablespace, truncating or dropping tables stored in a general tablespace creates free space internally in the general tablespace .ibd data file which can only be used for new - InnoDBdata. Space is not released back to the operating system as it is for file-per-table tablespaces.- Additionally, a table-copying - ALTER TABLEoperation on table that resides in a shared tablespace (a general tablespace or the system tablespace) can increase the amount of space used by the tablespace. Such operations require as much additional space as the data in the table plus indexes. The additional space required for the table-copying- ALTER TABLEoperation is not released back to the operating system as it is for file-per-table tablespaces.
- ALTER TABLE ... DISCARD TABLESPACEand- ALTER TABLE ...IMPORT TABLESPACEare not supported for tables that belong to a general tablespace.
- Support for placing table partitions in general tablespaces was deprecated in MySQL 5.7.24 and removed in MySQL 8.0.13. 
4.Undo Tablespaces
Undo tablespaces contain undo logs, which are collections of undo log records that contain information about how to undo the latest change by a transaction to a clustered index record. Undo logs exist within undo log segments, which are contained within rollback segments. The innodb_rollback_segments variable defines the number of rollback segments allocated to each undo tablespace.
Two default undo tablespaces are created when the MySQL instance is initialized. Default undo tablespaces are created at initialization time to provide a location for rollback segments that must exist before SQL statements can be accepted. A minimum of two undo tablespaces is required to support automated truncation of undo tablespaces.
Default undo tablespaces are created in the location defined by the innodb_undo_directory variable. If the innodb_undo_directory variable is undefined, default undo tablespaces are created in the data directory. Default undo tablespace data files are named undo_001 and undo_002. The corresponding undo tablespace names defined in the data dictionary are innodb_undo_001 and innodb_undo_002.
As of MySQL 8.0.14, additional undo tablespaces can be created at runtime using SQL.
The initial size of an undo tablespace data file depends on the innodb_page_size value. For the default 16KB page size, the initial undo tablespace file size is 10MiB. For 4KB, 8KB, 32KB, and 64KB page sizes, the initial undo tablespace files sizes are 7MiB, 8MiB, 20MiB, and 40MiB, respectively.
Adding Undo Tablespaces
Because undo logs can become large during long-running transactions, creating additional undo tablespaces can help prevent individual undo tablespaces from becoming too large. As of MySQL 8.0.14, additional undo tablespaces can be created at runtime using CREATE UNDO TABLESPACE syntax.
CREATE UNDO TABLESPACE tablespace_name ADD DATAFILE 'file_name.ibu'
The undo tablespace file name must have an .ibu extension. It is not permitted to specify a relative path when defining the undo tablespace file name. A fully qualified path is permitted, but the path must be known to InnoDB. Known paths are those defined by the innodb_directories variable. Unique undo tablespace file names are recommended to avoid potential file name conflicts when moving or cloning data.
At startup, directories defined by the innodb_directories variable are scanned for undo tablespace files. (The scan also traverses subdirectories.) Directories defined by the innodb_data_home_dir, innodb_undo_directory, and datadir variables are automatically appended to the innodb_directories value, regardless of whether theinnodb_directories variable is defined explicitly. An undo tablespace can therefore reside in paths defined by any of those variables.
If the undo tablespace file name does not include a path, the undo tablespace is created in the directory defined by the innodb_undo_directory variable. If that variable is undefined, the undo tablespace is created in the data directory.
注意:The InnoDB recovery process requires that undo tablespace files reside in known directories. Undo tablespace files must be discovered and opened before redo recovery and before other data files are opened to permit uncommitted transactions and data dictionary changes to be rolled back. An undo tablespace not found before recovery cannot be used, which can cause database inconsistencies. An error message is reported at startup if an undo tablespace known to the data dictionary is not found. The known directory requirement also supports undo tablespace portability.
To create undo tablespaces in a path relative to the data directory, set the innodb_undo_directory variable to the relative path, and specify the file name only when creating an undo tablespace.
To view undo tablespace names and paths, query INFORMATION_SCHEMA.FILES:
SELECT TABLESPACE_NAME, FILE_NAME FROM INFORMATION_SCHEMA.FILES
WHERE FILE_TYPE LIKE 'UNDO LOG';
A MySQL instance supports up to 127 undo tablespaces including the two default undo tablespaces created when the MySQL instance is initialized.
注意:
Prior to MySQL 8.0.14, additional undo tablespaces are created by configuring the innodb_undo_tablespaces startup variable. This variable is deprecated and no longer configurable as of MySQL 8.0.14.
Prior to MySQL 8.0.14, increasing the innodb_undo_tablespaces setting creates the specified number of undo tablespaces and adds them to the list of active undo tablespaces. Decreasing the innodb_undo_tablespaces setting removes undo tablespaces from the list of active undo tablespaces. Undo tablespaces that are removed from the active list remain active until they are no longer used by existing transactions. Theinnodb_undo_tablespaces variable can be configured at runtime using a SET statement or defined in a configuration file.
Prior to MySQL 8.0.14, deactivated undo tablespaces cannot be removed. Manual removal of undo tablespace files is possible after a slow shutdown but is not recommended, as deactivated undo tablespaces may contain active undo logs for some time after the server is restarted if open transactions were present when shutting down the server. As of MySQL 8.0.14, undo tablespaces can be dropped using DROP UNDO TABALESPACEsyntax.
Dropping Undo Tablespaces
As of MySQL 8.0.14, undo tablespaces created using CREATE UNDO TABLESPACE syntax can be dropped at runtime using DROP UNDO TABALESPACE syntax.
An undo tablespace must be empty before it can be dropped. To empty an undo tablespace, the undo tablespace must first be marked as inactive using ALTER UNDO TABLESPACE syntax so that the tablespace is no longer used for assigning rollback segments to new transactions.
ALTER UNDO TABLESPACE tablespace_name SET INACTIVE;
After an undo tablespace is marked as inactive, transactions currently using rollback segments in the undo tablespace are permitted to finish, as are any transactions started before those transactions are completed. After transactions are completed, the purge system frees the rollback segments in the undo tablespace, and the undo tablespace is truncated to its initial size. (The same process is used when truncating undo tablespaces. ) When the undo tablespace is empty, it can be dropped.
DROP UNDO TABLESPACE tablespace_name;
注意:Alternatively, the undo tablespace can be left in an empty state and reactivated later, when needed, by issuing an ALTER UNDO TABLESPACE statement.tablespace_name SET ACTIVE
The state of an undo tablespace can be monitored by querying the INFORMATION_SCHEMA.INNODB_TABLESPACES table.
SELECT NAME, STATE FROM INFORMATION_SCHEMA.INNODB_TABLESPACES
WHERE NAME LIKE tablespace_name;
An inactive state indicates that rollback segments in an undo tablespace are no longer used by new transactions. An empty state indicates that an undo tablespace is empty and ready to be dropped, or made active again using an ALTER UNDO TABLESPACE  statement. Attempting to drop an undo tablespace that is not empty returns an error.tablespace_name SET ACTIVE
The default undo tablespaces (innodb_undo_001 and innodb_undo_002) created when the MySQL instance is initialized cannot be dropped. They can, however, be made inactive using an ALTER UNDO TABLESPACE  statement. Before a default undo tablespace can be made inactive, there must be an undo tablespace to take its place. A minimum of two active undo tablespaces are required at all times to support automated truncation of undo tablespaces.tablespace_name SET INACTIVE
Configuring the Number of Rollback Segments
The innodb_rollback_segments variable defines the number of rollback segments allocated to each undo tablespace and to the global temporary tablespace. Theinnodb_rollback_segments variable can be configured at startup or while the server is running.
The default setting for innodb_rollback_segments is 128, which is also the maximum value.
Truncating Undo Tablespaces
There are two methods of truncating undo tablespaces, which can be used individually or in combination to manage undo tablespace size. One method is automated, enabled using configuration variables. The other method is manual, performed using SQL statements.
The automated method does not require monitoring undo tablespace size and, once enabled, it performs deactivation, truncation, and reactivation of undo tablespaces without manual intervention. The manual truncation method may be preferable if you want to control when undo tablespaces are taken offline for truncation. For example, you may want to avoid truncating undo tablespaces during peak workload times.
The purge thread is responsible for emptying and truncating undo tablespaces. By default, the purge thread looks for undo tablespaces to truncate once every 128 times that purge is invoked. The frequency with which the purge thread looks for undo tablespaces to truncate is controlled by the innodb_purge_rseg_truncate_frequencyvariable, which has a default setting of 128.
mysql> SELECT @@innodb_purge_rseg_truncate_frequency;
+----------------------------------------+
| @@innodb_purge_rseg_truncate_frequency |
+----------------------------------------+
| 128 |
+----------------------------------------+
To increase that frequency, decrease the innodb_purge_rseg_truncate_frequency setting. For example, to have the purge thread look for undo tabespaces once every 32 timees that purge is invoked, set innodb_purge_rseg_truncate_frequency to 32.
mysql> SET GLOBAL innodb_purge_rseg_truncate_frequency=32;
When the purge thread finds an undo tablespace that requires truncation, the purge thread returns with increased frequency to quickly empty and truncate the undo tablespace.
5 Temporary Tablespaces
InnoDB uses session temporary tablespaces and a global temporary tablespace.
Session Temporary Tablespaces
Session temporary tablespaces store user-created temporary tables and internal temporary tables created by the optimizer when InnoDB is configured as the storage engine for on-disk internal temporary tables. Beginning with MySQL 8.0.16, the storage engine used for on-disk internal temporary tables is always InnoDB. (Previously, the storage engine was determined by the value of internal_tmp_disk_storage_engine.)
Session temporary tablespaces are allocated to a session from a pool of temporary tablespaces on the first request to create an on-disk temporary table. A maximum of two tablespaces is allocated to a session, one for user-created temporary tables and the other for internal temporary tables created by the optimizer. The temporary tablespaces allocated to a session are used for all on-disk temporary tables created by the session. When a session disconnects, its temporary tablespaces are truncated and released back to the pool. A pool of 10 temporary tablespaces is created when the server is started. The size of the pool never shrinks and tablespaces are added to the pool automatically as necessary. The pool of temporary tablespaces is removed on normal shutdown or on an aborted initialization. Session temporary tablespace files are five pages in size when created and have an .ibt file name extension.
A range of 400 thousand space IDs is reserved for session temporary tablespaces. Because the pool of session temporary tablespaces is recreated each time the server is started, space IDs for session temporary tablespaces are not persisted when the server is shut down and may be reused.
The innodb_temp_tablespaces_dir variable defines the location where session temporary tablespaces are created. The default location is the #innodb_temp directory in the data directory. Startup is refused if the pool of temporary tablespaces cannot be created.
shell> cd BASEDIR/data/#innodb_temp
shell> ls
temp_10.ibt temp_2.ibt temp_4.ibt temp_6.ibt temp_8.ibt
temp_1.ibt temp_3.ibt temp_5.ibt temp_7.ibt temp_9.ibt
The INNODB_SESSION_TEMP_TABLESPACES table provides metadata about session temporary tablespaces.
The INFORMATION_SCHEMA.INNODB_TEMP_TABLE_INFO table provides metadata about user-created temporary tables that are active in an InnoDB instance.
Global Temporary Tablespace
The global temporary tablespace (ibtmp1) stores rollback segments for changes made to user-created temporary tables.
The innodb_temp_data_file_path variable defines the relative path, name, size, and attributes for global temporary tablespace data files. If no value is specified forinnodb_temp_data_file_path, the default behavior is to create a single auto-extending data file named ibtmp1 in the innodb_data_home_dir directory. The initial file size is slightly larger than 12MB.
The global temporary tablespace is removed on normal shutdown or on an aborted initialization, and recreated each time the server is started. The global temporary tablespace receives a dynamically generated space ID when it is created. Startup is refused if the global temporary tablespace cannot be created. The global temporary tablespace is not removed if the server halts unexpectedly. In this case, a database administrator can remove the global temporary tablespace manually or restart the MySQL server. Restarting the MySQL server removes and recreates the global temporary tablespace automatically.
The global temporary tablespace cannot reside on a raw device.
INFORMATION_SCHEMA.FILES provides metadata about the global temporary tablespace. Issue a query similar to this one to view global temporary tablespace metadata:
SELECT * FROM INFORMATION_SCHEMA.FILES WHERE TABLESPACE_NAME='innodb_temporary'\G
By default, the global temporary tablespace data file is autoextending and increases in size as necessary.
To determine if a global temporary tablespace data file is autoextending, check the innodb_temp_data_file_path setting:
mysql> SELECT @@innodb_temp_data_file_path;
+------------------------------+
| @@innodb_temp_data_file_path |
+------------------------------+
| ibtmp1:12M:autoextend |
+------------------------------+
To check the size of global temporary tablespace data files, query the INFORMATION_SCHEMA.FILES table using a query similar to this one:
mysql> SELECT FILE_NAME, TABLESPACE_NAME, ENGINE, INITIAL_SIZE, TOTAL_EXTENTS*EXTENT_SIZE
AS TotalSizeBytes, DATA_FREE, MAXIMUM_SIZE FROM INFORMATION_SCHEMA.FILES
WHERE TABLESPACE_NAME = 'innodb_temporary'\G
*************************** 1. row ***************************
FILE_NAME: ./ibtmp1
TABLESPACE_NAME: innodb_temporary
ENGINE: InnoDB
INITIAL_SIZE: 12582912
TotalSizeBytes: 12582912
DATA_FREE: 6291456
MAXIMUM_SIZE: NULL
TotalSizeBytes shows the current size of the global temporary tablespace data file.
Alternatively, check the global temporary tablespace data file size on your operating system. The global temporary tablespace data file is located in the directory defined by the innodb_temp_data_file_path variable.
To reclaim disk space occupied by a global temporary tablespace data file, restart the MySQL server. Restarting the server removes and recreates the global temporary tablespace data file according to the attributes defined by innodb_temp_data_file_path.
To limit the size of the global temporary tablespace data file, configure innodb_temp_data_file_path to specify a maximum file size. For example:
[mysqld]
innodb_temp_data_file_path=ibtmp1:12M:autoextend:max:500M
Configuring innodb_temp_data_file_path requires restarting the server.
6 Creating a Tablespace Outside of the Data Directory
The CREATE TABLE ... DATA DIRECTORY clause permits creating a file-per-table tablespace outside of the data directory. For example, you can use the DATA DIRECTORYclause to create a tablespace on a separate storage device with particular performance or capacity characteristics, such as a fast SSD or a high-capacity HDD.
Be sure of the location that you choose. The DATA DIRECTORY clause cannot be used with ALTER TABLE to change the location later.
The tablespace data file is created in the specified directory, within in a subdirectory named for the schema to which the table belongs.
The following example demonstrates creating a file-per-table tablespace outside of the data directory. It is assumed that the innodb_file_per_table variable is enabled.
mysql> USE test;
Database changed mysql> CREATE TABLE t1 (c1 INT PRIMARY KEY) DATA DIRECTORY = '/remote/directory'; # MySQL creates the tablespace file in a subdirectory that is named
# for the schema to which the table belongs shell> cd /remote/directory/test
shell> ls
t1.ibd
When creating a tablespace outside of the data directory, ensure that the directory is known to InnoDB. Otherwise, if the server halts unexpectedly before tablespace data file pages are fully flushed, startup fails when the tablespace is not found during the pre-recovery discovery phase that searches known directories for tablespace data files. To make a directory known, add it to the innodb_directories argument value. innodb_directories is a read-only startup option that defines directories to scan at startup for tablespace data files. Configuring it requires restarting the server.
CREATE TABLE ... TABLESPACE syntax can also be used in combination with the DATA DIRECTORY clause to create a file-per-table tablespace outside of the data directory. To do so, specify innodb_file_per_table as the tablespace name.
mysql> CREATE TABLE t2 (c1 INT PRIMARY KEY) TABLESPACE = innodb_file_per_table
DATA DIRECTORY = '/remote/directory';
The innodb_file_per_table variable does not need to be enabled when using this method.
Usage Notes:
- MySQL initially holds the tablespace data file open, preventing you from dismounting the device, but might eventually close the table if the server is busy. Be careful not to accidentally dismount an external device while MySQL is running, or start MySQL while the device is disconnected. Attempting to access a table when the associated tablespace data file is missing causes a serious error that requires a server restart. - A server restart issues errors and warnings if the tablespace data file is not at the expected path. In this case, you can restore the tablespace data file from a backup or drop the table to remove the information about it from the data dictionary. 
- Before placing a tablespace on an NFS-mounted volume, review potential issues outlined in Using NFS with MySQL. 
- If using an LVM snapshot, file copy, or other file-based mechanism to back up the tablespace data file, always use the - FLUSH TABLES ... FOR EXPORTstatement first to ensure that all changes buffered in memory are flushed to disk before the backup occurs.
- Using the - DATA DIRECTORYclause is an alternative to using symbolic links, which is not supported.
7 Copying Tablespaces to Another Instance
This section describes how to copy a file-per-table tablespaces from one MySQL instance to another, otherwise known as the Transportable Tablespaces feature. This feature also supports partitioned InnoDB tables and individual InnoDB table partitions and subpartitions.
There are many reasons why you might copy an InnoDB file-per-table tablespace to a different instance:
- To run reports without putting extra load on a production server. 
- To set up identical data for a table on a new slave server. 
- To restore a backed-up version of a table or partition after a problem or mistake. 
- As a faster way of moving data around than importing the results of a mysqldump command. The data is available immediately, rather than having to be re-inserted and the indexes rebuilt. 
- To move a file-per-table tablespace to a server with storage medium that better suits system requirements. For example, you may want to have busy tables on an SSDdevice, or large tables on a high-capacity HDD device. 
Limitations and Usage Notes
- The tablespace copy procedure is only possible when - innodb_file_per_tableis enabled, which is the default setting. Tables residing in the shared system tablespace cannot be quiesced.
- When a table is quiesced, only read-only transactions are allowed on the affected table. 
- When importing a tablespace, the page size must match the page size of the importing instance. 
- ALTER TABLE ... DISCARD TABLESPACEis supported for partitioned- InnoDBtables, and- ALTER TABLE ... DISCARD PARTITION ... TABLESPACEis supported for- InnoDBtable partitions.
- DISCARD TABLESPACEis not supported for tablespaces with a parent-child (primary key-foreign key) relationship when- foreign_key_checksis set to- 1. Before discarding a tablespace for parent-child tables, set- foreign_key_checks=0. Partitioned- InnoDBtables do not support foreign keys.
- ALTER TABLE ... IMPORT TABLESPACEdoes not enforce foreign key constraints on imported data. If there are foreign key constraints between tables, all tables should be exported at the same (logical) point in time. Partitioned- InnoDBtables do not support foreign keys.
- ALTER TABLE ... IMPORT TABLESPACEand- ALTER TABLE ... IMPORT PARTITION ... TABLESPACEdo not require a- .cfgmetadata file to import a tablespace. However, metadata checks are not performed when importing without a- .cfgfile, and a warning similar to the following is issued:- Message: InnoDB: IO Read error: (, No such file or directory) Error opening '.\ 
 test\t.cfg', will attempt to import without schema verification
 row in set (0.00 sec)- The ability to import without a - .cfgfile may be more convenient when no schema mismatches are expected. Additionally, the ability to import without a- .cfgfile could be useful in crash recovery scenarios in which metadata cannot be collected from an- .ibdfile.- If no - .cfgfile is used,- InnoDBuses the equivalent of a- SELECT MAX(ai_col) FROMstatement to initialize the in-memory auto-increment counter that is used in assigning values for to an- table_nameFOR UPDATE- AUTO_INCREMENTcolumn. Otherwise, the current maximum auto-increment counter value is read from the- .cfgmetadata file. For related information, see InnoDB AUTO_INCREMENT Counter Initialization.
- Due to a - .cfgmetadata file limitation, schema mismatches are not reported for partition type or partition definition differences when importing tablespace files for partitioned tables. Column differences are reported.
- When running - ALTER TABLE ... DISCARD PARTITION ... TABLESPACEand- ALTER TABLE ... IMPORT PARTITION ... TABLESPACEon subpartitioned tables, both partition and subpartition table names are allowed. When a partition name is specified, subpartitions of that partition are included in the operation.
- Importing a tablespace file from another MySQL server instance works if both instances have GA (General Availability) status and the server instance into which the file is imported is at the same or higher release level within the same release series. Importing a tablespace file into a server instance running an earlier release of MySQL is not supported. 
- In replication scenarios, - innodb_file_per_tablemust be set to- ONon both the master and slave.
- On Windows, - InnoDBstores database, tablespace, and table names internally in lowercase. To avoid import problems on case-sensitive operating systems such as Linux and UNIX, create all databases, tablespaces, and tables using lowercase names. A convenient way to accomplish this is to add the following line to the- [mysqld]section of your- my.cnfor- my.inifile before creating databases, tablespaces, or tables:- [mysqld] 
 lower_case_table_names=1注意:It is prohibited to start the server with a- lower_case_table_namessetting that is different from the setting used when the server was initialized.
- ALTER TABLE ... DISCARD TABLESPACEand- ALTER TABLE ...IMPORT TABLESPACEare not supported with tables that belong to an- InnoDBgeneral tablespace. For more information, see- CREATE TABLESPACE.
- The default row format for - InnoDBtables is configurable using the- innodb_default_row_formatconfiguration option. Attempting to import a table that does not explicitly define a row format (- ROW_FORMAT), or that uses- ROW_FORMAT=DEFAULT, could result in a schema mismatch error if the- innodb_default_row_formatsetting on the source instance differs from the setting on the destination instance. For related information, see Defining the Row Format of a Table.
- When exporting an encrypted tablespace, - InnoDBgenerates a- .cfpfile in addition to a- .cfgmetadata file. The- .cfpfile must be copied to the destination instance together with the- .cfgfile and tablespace file before performing the- ALTER TABLE ... IMPORT TABLESPACEoperation on the destination instance. The- .cfpfile contains a transfer key and an encrypted tablespace key. On import,- InnoDBuses the transfer key to decrypt the tablespace key. For related information, seeSection 15.6.3.9, “InnoDB Data-at-Rest Encryption”.
- FLUSH TABLES ... FOR EXPORTis not supported on tables that have a FULLTEXT index. Full-text search auxiliary tables are not flushed. After importing a table with a- FULLTEXTindex, run- OPTIMIZE TABLEto rebuild the- FULLTEXTindexes. Alternatively, drop- FULLTEXTindexes before the export operation and recreate them after importing the table on the destination instance.
8 Moving Tablespace Files While the Server is Offline
The innodb_directories option, which defines directories to scan at startup for tablespace files, supports moving or restoring tablespace files to a new location while the server is offline. During startup, discovered tablespace files are used instead those referenced in the data dictionary, and the data dictionary is updated to reference the relocated files. If duplicate tablespace files are discovered by the scan, startup fails with an error indicating that multiple files were found for the same tablespace ID.
The directories defined by the innodb_data_home_dir, innodb_undo_directory, and datadir configuration options are automatically appended to theinnodb_directories argument value. These directories are scanned at startup regardless of whether the innodb_directories option is specified explicitly. The implicit addition of these directories permits moving system tablespace files, the data directory, or undo tablespace files without configuring the innodb_directories setting. However, settings must be updated when directories change. For example, after relocating the data directory, you must update the --datadir setting before restarting the server.
The innodb_directories option may be specified in a startup command or MySQL option file. Quotes are used around the argument value because otherwise a semicolon (;) is interpreted as a special character by some command interpreters.
MySQL option file:
[mysqld]
innodb_directories="directory_path_1;directory_path_2"
The following procedure is applicable to moving individual file-per-table and general tablespace files, system tablespace files, undo tablespace files, or the data directory. Before moving files or directories, review the usage notes that follow.
- Stop the server. 
- Move the tablespace files or directories. 
- Make the new directory known to - InnoDB.- If moving individual file-per-table or general tablespace files, add unknown directories to the - innodb_directoriesvalue.- The directories defined by the - innodb_data_home_dir,- innodb_undo_directory, and- datadirconfiguration options are automatically appended to the- innodb_directoriesargument value, so you need not specify these.
- A file-per-table tablespace file can only be moved to a directory with same name as the schema. For example, if the - actortable belongs to the- sakilaschema, then the- actor.ibddata file can only be moved to a directory named- sakila.
- General tablespace files cannot be moved to the data directory or a subdirectory of the data directory. 
 
- If moving system tablespace files, undo tablespaces, or the data directory, update the - innodb_data_home_dir,- innodb_undo_directory, and- datadirsettings, as necessary.
 
- Restart the server. 
Usage Notes
- Wildcard expressions cannot be used in the - innodb_directoriesargument value.
- The - innodb_directoriesscan also traverses subdirectories of specified directories. Duplicate directories and subdirectories are discarded from the list of directories to be scanned.
- The - innodb_directoriesoption only supports moving- InnoDBtablespace files. Moving files that belong to a storage engine other than- InnoDBis not supported. This restriction also applies when moving the entire data directory.
- The - innodb_directoriesoption supports renaming of tablespace files when moving files to a scanned directory. It also supports moving tablespaces files to other supported operating systems.
- When moving tablespace files to a different operating system, ensure that tablespace file names do not include prohibited characters or characters with a special meaning on the destination system. 
- When moving a data directory from a Windows operating system to a Linux operating system, modify the binary log file paths in the binary log index file to use backward slashes instead of forward slashes. By default, the binary log index file has the same base name as the binary log file, with the extension ' - .index'. The location of the binary log index file is defined by- --log-bin. The default location is the data directory.
- If moving tablespace files to a different operating system introduces cross-platform replication, it is the responsibility of the Database Administrator to ensure proper replication of DDL statements that contain platform-specific directories. Statements that permit specifying directories include - CREATE TABLE ... DATA DIRECTORYand- CREATE TABLESPACE.
- The directory of file-per-table and general tablespace files created with an absolute path or in a location outside of the data directory should be added to the - innodb_directoriesargument value. Otherwise,- InnoDBis not able to locate these files during recovery.- CREATE TABLE ... DATA DIRECTORYand- CREATE TABLESPACEpermit creation of tablespace files with absolute paths.- CREATE TABLESPACEalso permits tablespace file directories that are relative to the data directory. To view tablespace file locations, query the- INFORMATION_SCHEMA.FILEStable:- mysql> SELECT TABLESPACE_NAME, FILE_NAME FROM INFORMATION_SCHEMA.FILES \G 
- CREATE TABLESPACErequires that the target directory exists and is known to- InnoDB. Known directories include those implicitly and explicitly defined by the- innodb_directoriesoption.
9 InnoDB Data-at-Rest Encryption
InnoDB supports data-at-rest encryption for file-per-table tablespaces, general tablespaces, the mysql system tablespace, redo logs, and undo logs.
As of MySQL 8.0.16, setting an encryption default for schemas and general tablespaces is also supported, which permits DBAs to control whether tables created in those schemas and tablespaces are encrypted.
InnoDB uses a two tier encryption key architecture, consisting of a master encryption key and tablespace keys. When a tablespace is encrypted, a tablespace key is encrypted and stored in the tablespace header. When an application or authenticated user wants to access encrypted tablespace data, InnoDB uses a master encryption key to decrypt the tablespace key. The decrypted version of a tablespace key never changes, but the master encryption key can be changed as required. This action is referred to as master key rotation.
The data-at-rest encryption feature relies on a keyring plugin for master encryption key management.
All MySQL editions provide a keyring_file plugin, which stores keyring data in a file local to the server host.
MySQL Enterprise Edition offers additional keyring plugins:
- The - keyring_encrypted_fileplugin, which stores keyring data in an encrypted file local to the server host.
- The - keyring_okvplugin, which includes a KMIP client (KMIP 1.1) that uses a KMIP-compatible product as a back end for keyring storage. Supported KMIP-compatible products include centralized key management solutions such as Oracle Key Vault, Gemalto KeySecure, Thales Vormetric key management server, and Fornetix Key Orchestration.
- The - keyring_awsplugin, which communicates with the Amazon Web Services Key Management Service (AWS KMS) as a back end for key generation and uses a local file for key storage.
keyring_file and keyring_encrypted file plugins are not intended as regulatory compliance solutions. Security standards such as PCI, FIPS, and others require use of key management systems to secure, manage, and protect encryption keys in key vaults or hardware security modules (HSMs).A secure and robust encryption key management solution is critical for security and for compliance with various security standards. When the data-at-rest encryption feature uses a centralized key management solution, the feature is referred to as “MySQL Enterprise Transparent Data Encryption (TDE)”.
The data-at-rest encryption feature supports the Advanced Encryption Standard (AES) block-based encryption algorithm. It uses Electronic Codebook (ECB) block encryption mode for tablespace key encryption and Cipher Block Chaining (CBC) block encryption mode for data encryption.
转载、节选于 https://dev.mysql.com/doc/refman/8.0/en/innodb-tablespace.html
InnoDB On-Disk Structures(三)--Tablespaces (转载)的更多相关文章
- 14.5.7 Storing InnoDB Undo Logs in Separate Tablespaces 存储InnoDB Undo logs 到单独的表空间
		14.5.7 Storing InnoDB Undo Logs in Separate Tablespaces 存储InnoDB Undo logs 到单独的表空间 在MySQL 5.6.3,你可以存 ... 
- Android 之窗口小部件详解(三)  部分转载
		原文地址:http://blog.csdn.net/iefreer/article/details/4626274. (一) 应用程序窗口小部件App Widgets 应用程序窗口小部件(Widget ... 
- SQL2005中的事务与锁定(三)- 转载
		------------------------------------------------------------------------ -- Author : HappyFlyStone ... 
- 多屏复杂动画CSS技巧三则(转载)
		本文转载自: 经验分享:多屏复杂动画CSS技巧三则 
- mysql innodb 数据打捞(三)innodb 簇不连接页的扫描提取(计划)
		操作系统簇大小一般是4K,而innoDB的页大小一般是16K,那么就有可能16K的页没有存储在连续的簇中,这样扫描软件就不会扫描出来这样的页面.为了解决这个问题,决定给软件增加半页扫描功能. 在第一次 ... 
- MySQL数据库MyISAM和InnoDB存储引擎的比较【转载】
		转自 http://www.cnblogs.com/panfeng412/archive/2011/08/16/2140364.html MySQL有多种存储引擎,MyISAM和InnoDB是其中常用 ... 
- InnoDB体系架构(三)Checkpoint技术
		Checkpoint技术 前篇 InnoDB体系架构(二)内存 从缓冲池.缓冲池的管理.重做日志缓冲.额外内存缓冲这四个点介绍了InnoDB存储引擎的内存结构,而在将缓冲池的数据刷新到磁盘的过程中使用 ... 
- ASP.NET Identity 三(转载)
		转载来源:http://www.cnblogs.com/r01cn/p/5194257.html 注:本文是[ASP.NET Identity系列教程]的第三篇.本系列教程详细.完整.深入地介绍了微软 ... 
- 使用rem设计移动端自适应页面三(转载)
		使用rem 然后根据媒体查询实现自适应.跟使用JS来自适应也是同个道理,不过是js更精确一点.使用媒体查询: html { font-size: 62.5% } @media only screen ... 
随机推荐
- Java修炼——递归算法的俩个实例
			1.是输出指定文件目录下的所以子目录以及文件 2.使用递归算算法:1!+2!+3!+4!+5!+-+n!(计算阶乘累加) package com.bjsxt.recurison; import jav ... 
- Java并发编程系列-(2) 线程的并发工具类
			2.线程的并发工具类 2.1 Fork-Join JDK 7中引入了fork-join框架,专门来解决计算密集型的任务.可以将一个大任务,拆分成若干个小任务,如下图所示: Fork-Join框架利用了 ... 
- Orleans 序列化遇到的坑
			真的是巨坑 搞明白问题的我简直无法用言语来描述我的心情 先上架构图 理想中的架构 服务随便上 网关只负责分发 然后跟随官方教程写遇到了序列化问题 以前有经验,不慌,以前稀里糊涂就搞定了. 再然后遇到一 ... 
- Pycharm-2018.3.1专业版破解教程
			1.去官网下载并安装2018.3.1(目前最新)专业版本的Pycharm:(https://www.jetbrains.com/pycharm/download/#section=windows). ... 
- jenkins+gitlab+webhook实现自动发布
			实验环境 Jenkins:192.168.1.15 Gitlab:192.168.1.14 一.Jenkins配置 1:安装gitlab hook plugin插件 2:新建一个job 3 ... 
- 【JPA】注解@PostConstruct、@PreDestroy
			从Java EE5规范开始,Servlet增加了两个影响Servlet生命周期的注解@PostConstruct和@PreConstruct.这两个注解被用来修饰一个非静态的void()方法,而且这个 ... 
- Python基础-day01-6
			算数运算符 计算机,顾名思义就是负责进行 数学计算 并且 存储计算结果 的电子设备 目标 算术运算符的基本使用 01. 算数运算符 算数运算符是 运算符的一种 是完成基本的算术运算使用的符号,用来处理 ... 
- 《.Net 最佳实践》 - 学习笔记
			<.Net 最佳实践> ========== ========== ==========[作者] (美) Stephen Ritchie[译者] (中) 黄灯桥 黄浩宇 李永[出版] 机械 ... 
- 1.Python  简单输入输出
			1 读取:input() 1.1 简单打印内容 In [1]: input('你好,请输入你的名字:') 你好,请输入你的名字:小明 1.2 保存输入内容 In [2]: CN_Name = inpu ... 
- QT获取linux下的当前用户名
			故事背景:客户端启动的时候需要加载机器/home/xx/test.jpg的图片作为背景图,但是有的机器用户名叫AAA,有的机器名叫BBB,所以我需要获取当前用户的home目录 技术调研:QStanda ... 
