麒麟v10 上部署 TiDB v5.1.2 生产环境优化实践
569
2023-07-07
mysql中表空间传输的示例分析
说明:MySQL(5.6.6及以上),innodb_file_per_table开启。
1.1. 操作步骤:
0. 目标服务器创建相同表结构1. 目的服务器: ALTER TABLE t DISCARD TABLESPACE;2. 源服务器 : FLUSH TABLES t FOR EXPORT;3. 从源服务器上 拷贝t.ibd, t.cfg文件到目的服务器4. 源服务器: UNLOCK TABLES;5. 目的服务器: ALTER TABLE t IMPORT TABLESPACE;
1.2. 演示将多实例的 [mysql5711] 中 burn_test 库下的test_purge表 ,传输到 [mysql57112]中 burn_test2 库下的test_purge表
1.2.1. 准备工作
1. 在 目标服务器 上创建表空间
-- 源服务器 [mysql5711]
mysql> select * from burn_test.test_purge;+----+------+| a | b |+----+------+| 1 | 10 || 3 | 30 || 4 | 40 || 5 | 50 || 6 | 60 || 7 | 70 || 8 | 80 || 10 | 100 |+----+------+8 rows in set (0.01 sec)
-- 目标服务器 [mysql57112]---- test_purge在 目标服务器 上不存在,先创建该表mysql> CREATE TABLE `test_purge` (`a` int(11) NOT NULL AUTO_INCREMENT,`b` int(11) DEFAULT NULL,PRIMARY KEY (`a`),UNIQUE KEY `b` (`b`)) ENGINE=InnoDB AUTO_INCREMENT=11 DEFAULT CHARSET=utf8mb4;Query OK, 0 rows affected (0.16 sec)
2. 创建完成后进行检查## 目标服务器#[root@MyServer burn_test_2]> ll | grep test_purge-rw-r-----. 1 mysql mysql 8578 Mar 21 10:31 test_purge.frm # 表结构-rw-r-----. 1 mysql mysql 57344 Mar 21 10:31 test_purge.ibd # 表空间,需要通过 DISCARD 将表空间文件删除ALTER TABLE test_purge DISCARD TABLESPACE; 的含义是 保留test_purge.frm 文件, 删除test_purge.ibd
3. 通辟 discard 删除ibd文件
-- 目标服务器
mysql> alter table test_purge discard tablespace;Query OK, 0 rows affected (0.04 sec)mysql> show tables;+-----------------------+| Tables_in_burn_test_2 |+-----------------------+| test_backup1 || test_purge |+-----------------------+2 rows in set (0.00 sec)mysql> select * from test_purge;ERROR 1814 (HY000): Tablespace has been discarded for table 'test_purge'[root@MyServer burn_test_2]> ll | grep test_purge-rw-r-----. 1 mysql mysql 8578 Mar 21 10:31 test_purge.frm
1.2.2. 导出表空间1. 在源服务器上,通辟 export 命令导出表空间(同时加读锁)
-- 源服务器
mysql> flush table test_purge for export; -- 其实是对这个表加一个读锁Query OK, 0 rows affected (0.00 sec)2. 将导出的 cfg文件 和 ibd文件 , 拷贝到目标服务器 的数据库下## 源服务器#[root@MyServer burn_test]> ll | grep test_purge-rw-r-----. 1 mysql mysql 462 Mar 21 10:58 test_purge.cfg # export后,多出来的文件,里面保存了一些元数据信息-rw-r-----. 1 mysql mysql 8578 Mar 4 15:41 test_purge.frm-rw-r-----. 1 mysql mysql 57344 Mar 5 15:28 test_purge.ibd[root@MyServer burn_test]> cp test_purge.cfg test_purge.ibd /data/mysql_data/5.7.11_2/burn_test_2/ # 拷贝表空间和cfg文件,远程请使用scp(本地多实例演示,这里的库名是不同的)3. 导出表空间后,尽快解锁
-- 源服务器
mysql> unlock tables; -- 尽快的解锁Query OK, 0 rows affected (0.00 sec)注意:一定要先拷贝cfg和ibd文件,然后才能unlock,因为 unlock 的时候, cfg文件会被删除# 源服务器上的日志[Note] InnoDB: Stopping purge # 其实stop purge,找个测试的表 for export 即可[Note] InnoDB: Writing table metadata to './burn_test/test_purge.cfg'[Note] InnoDB: Table `burn_test`.`test_purge` flushed to disk[Note] InnoDB: Deleting the meta-data file './burn_test/test_purge.cfg' # unlock table后,该文件自动被删除[Note] InnoDB: Resuming purge # unlock后,恢复purge线程4. 在目标服务器上 修改 cfg文件和ibd文件的 权限## 目标服务器#[root@MyServer burn_test_2]> chown mysql.mysql test_purge.cfg test_purge.ibd5. 在目标服务器上通辟 import 命令导入表空间-- 目标服务器--mysql> alter table test_purge import tablespace; -- 导入表空间Query OK, 0 rows affected (0.24 sec)mysql> select * from test_purge; -- 可以读取到从源服务器拷贝过来的数据+----+------+| a | b |+----+------+| 1 | 10 || 3 | 30 || 4 | 40 || 5 | 50 || 6 | 60 || 7 | 70 || 8 | 80 || 10 | 100 |+----+------+8 rows in set (0.00 sec)
# error.log中出现的信息InnoDB: Importing tablespace for table 'burn_test/test_purge' that was exported from host 'MyServer'
注意:表的名称必须相同 ,经过上述测试,库名可以不同该方法也可以用于分区表的备份和恢复
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。