使用可移动表空间执行InnoDB备份

备份InnoDB的表时,可以使用可移动表空间执行部分备份,可以备份单独的表,也可以备份具有相同业务功能的多个表。

图片[1]-使用可移动表空间执行InnoDB备份-不念博客

当用户将希望将源服务器上的一个表复制到另外一台服务器上时,可以采用可移动表空间来实现,具体如下:

1、我们可以在源服务器上执行“FLUSH TABLE … FOR EXPORT”将表静止并创建“.cfg”元数据文件。

SQL > FLUSH TABLES actor FOR EXPORT;
SQL > FLUSH TABLES actor FOR EXPORT;
SQL > FLUSH TABLES actor FOR EXPORT;

“.cfg”文件将会创建在数据路径下:

C:\ProgramData\MySQL\MySQL Server 8.3\Data\sakila 的目录
2024/03/25 9:24 <DIR> .
2024/03/25 9:59 <DIR> ..
2024/03/25 9:24 1,003 actor.cfg
2024/03/25 9/:51 131,072 actor.ibd
C:\ProgramData\MySQL\MySQL Server 8.3\Data\sakila 的目录

2024/03/25  9:24    <DIR>          .
2024/03/25  9:59    <DIR>          ..
2024/03/25  9:24             1,003 actor.cfg
2024/03/25  9/:51           131,072 actor.ibd
C:\ProgramData\MySQL\MySQL Server 8.3\Data\sakila 的目录 2024/03/25 9:24 <DIR> . 2024/03/25 9:59 <DIR> .. 2024/03/25 9:24 1,003 actor.cfg 2024/03/25 9/:51 131,072 actor.ibd

2、将.ibd”文件和“.cfg”文件复制到目标服务器。

3、在源服务器上执行“UNLOCK TABLES”释放表上的锁。

4、在目标服务器上创建一个相同结构的表,之后销毁表空间

SQL >ALTER TABLE actor DISCARD TABLESPACE;
SQL >ALTER TABLE actor DISCARD TABLESPACE;
SQL >ALTER TABLE actor DISCARD TABLESPACE;

5、在目标服务器上导入复制过来的表空间

SQL >ALTER TABLE actor IMPORT TABLESPACE;
SQL >ALTER TABLE actor IMPORT TABLESPACE;
SQL >ALTER TABLE actor IMPORT TABLESPACE;

如果我们进行备份的是带有分区的InnoDB表,则需要对每个分区导出元数据文件,并将每个分区的.ibd”文件和“.cfg”文件执行导出、导入的操作。

© 版权声明
THE END