使用MySQL传输表空间迁移数据
对于大表的迁移,如果使用mysqldump进行导出,然后重新导入到其它环境,速度是非常缓慢的。如果使用传输表空间,则可以解决这个问题。
测试使用传输表空间迁移表,基础环境如下:
| 源库 | 目标库 | |
| IP地址 | 192.168.10.11 | 192.168.10.12 |
| 数据库版本 | 5.7.24 | 5.7.24 |
| 数据库名称 | db1 | db2 |
| 待迁移的表 | test01 |
(1)在目标库创建和源库相同的表test01
先在主库db1上查看表信息,并生成创建表的语句
mysql> select count(*) from test01;
+----------+
| count(*) |
+----------+
| 10000 |
+----------+
1 row in set (0.00 sec) mysql> show create table test01;
+--------+--------------------------------------------------------+
| Table | Create Table |
+--------+-------------------------------------------------------+
| test01 | CREATE TABLE `test01` (
`id1` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(30) DEFAULT NULL,
PRIMARY KEY (`id1`)
) ENGINE=InnoDB AUTO_INCREMENT=10001 DEFAULT CHARSET=utf8 |
+--------+-----------------------------------------------------+
1 row in set (0.00 sec)
在目标数据库db2上创建表test01
mysql> CREATE TABLE `test01` (
-> `id1` int(11) NOT NULL AUTO_INCREMENT,
-> `name` varchar(30) DEFAULT NULL,
-> PRIMARY KEY (`id1`)
-> ) ENGINE=InnoDB AUTO_INCREMENT=10001 DEFAULT CHARSET=utf8 ;
Query OK, 0 rows affected (0.00 sec)
(2)目标数据库db2上丢弃表空间
在丢弃表空间后,test01表的ibd文件会被删除
[root@slavedb db2]# pwd
/mysql/data/db2
[root@slavedb db2]# ls
db.opt test01.frm test01.ibd mysql> alter table test01 discard tablespace;
Query OK, 0 rows affected (0.01 sec) [root@slavedb db2]# ls
db.opt test01.frm
此时,test01表还在db2中,但是已经无法访问
mysql> show tables;
+---------------+
| Tables_in_db2 |
+---------------+
| test01 |
+---------------+
1 row in set (0.00 sec) mysql> select * from test01;
ERROR 1814 (HY000): Tablespace has been discarded for table 'test01'
(3)导出源库db1上的test01表
先对表db1.test01加上读锁,此时,db1.test01可读,但是不可写
mysql> flush table test01 for export;
Query OK, 0 rows affected (0.00 sec)
执行完export后,会生成一个test01.cfg文件
[root@masterdb db1]# pwd
/mysql/data/db1
[root@masterdb db1]# ls -l
total 18472
-rw-r----- 1 mysql mysql 61 Feb 11 14:28 db.opt
-rw-r----- 1 mysql mysql 388 Feb 11 15:06 test01.cfg
-rw-r----- 1 mysql mysql 8588 Feb 11 14:29 test01.frm
-rw-r----- 1 mysql mysql 9437184 Feb 11 14:29 test01.ibd
将test01.ibd和test01.cfg文件拷贝到目标数据库db2的数据文件路径下
[root@masterdb db1]# scp test01.cfg test01.ibd root@192.168.10.12:/mysql/data/db2/
root@192.168.10.12's password:
test01.cfg 100% 388 324.4KB/s 00:00
test01.ibd 100% 9216KB 59.6MB/s 00:00
传输结束后,释放test01表的读锁
mysql> unlock tables;
Query OK, 0 rows affected (0.00 sec)
(4)修改目标数据库db2的test01.ibd和test01.cfg文件权限
[root@slavedb db2]# chown mysql:mysql test01.ibd test01.cfg
[root@slavedb db2]# ls -l
total 9236
-rw-r----- 1 mysql mysql 61 Feb 11 14:30 db.opt
-rw-r----- 1 mysql mysql 388 Feb 11 15:10 test01.cfg
-rw-r----- 1 mysql mysql 8588 Feb 11 14:58 test01.frm
-rw-r----- 1 mysql mysql 9437184 Feb 11 15:10 test01.ibd
(5)在db2上加载test01表
mysql> alter table test01 import tablespace;
Query OK, 0 rows affected (0.02 sec) mysql> select count(*) from test01;
+----------+
| count(*) |
+----------+
| 10000 |
+----------+
1 row in set (0.00 sec)
可以看到,test01表数据已经正常传输过来。
【完】
使用MySQL传输表空间迁移数据的更多相关文章
- mysql 案例 ~ 表空间迁移数据与数据导入
一 简介:mysql5.6+的表空间传输二 目的:复制数据到另一个表三 步骤 1 create table b like a ->创建一个空表 2 alter table b disc ...
- RMAN传输表空间迁移数据
实验环境: 源数据库:oracle 10g(Release 10.2.0.1.0) 目标数据库:oracle 10g(Release 10.2.0.1.0) 待传输的表空间:TEST 1.在tes ...
- mysql5.6之 传输表空间迁移表或恢复误删除的表
一,简单说明: 1),传输表空间的限制: 1,mysql 版本 5.6.6 及其以上,并且版本建议源和目标版本建议都是GA版并且大版本一样 2,表引擎为innodb并且开启独立表空间 innod ...
- 如何通过RMAN使用传输表空间迁移到不同的Endian平台 (Doc ID 371556.1)
How to Migrate to different Endian Platform Using Transportable Tablespaces With RMAN (Doc ID 371556 ...
- MySQL传输表空间使用方法
1.目标端创建同样的表结构 CREATE TABLE `test` ( `id` int(11) DEFAULT NULL ) ENGINE=InnoDB DEFAULT CHAR ...
- oracle操作之传输表空间
一.传输表空间概述 什么是传输表空间,传输表空间技术始于oracle9i,不论是数据字典管理的表空间还是本地管理的表空间,都可以使用传输表空间技术:传输表空间不需要在源数据库和目标数据库之间具有同样的 ...
- [20170623]利用传输表空间恢复部分数据.txt
[20170623]利用传输表空间恢复部分数据.txt --//昨天我测试使用传输表空间+dblink,上午补充测试发现表空间设置只读才能执行impdp导入原数据,这个也很好理解.--//这样的操作模 ...
- 转 Oracle Transportable TableSpace(TTS) 传输表空间 说明
############1 迁移数据库的集中方法 三.相关技术 迁移方式 优势 不足1 Export and import • 对数据库版本,以及系统平台没有要求 • 不支持并发,速度慢• 停机时 ...
- 【TTS】传输表空间AIX asm -> linux asm
[TTS]传输表空间AIX asm -> linux asm 一.1 BLOG文档结构图 一.2 前言部分 一.2.1 导读和注意事项 各位技术爱好者,看完本文后,你可以掌 ...
随机推荐
- python 4个人中有一人做了好事,一直有三个人说了真话,根据下面的对话判断是谁做的好事
题目:4个人中有一人做了好事,一直有三个人说了真话,根据下面的对话判断是谁做的好事. A:不是我 B:是C C:是D D:C胡说 for inum in ['A','B','C','D']: prin ...
- [JZOJ]1293.气象牛[区间DP]
Description 为了研究农场的气候,Betsy帮助农夫John做了N(1 <= N <= 100)次气压测量并按顺序记录了结果M_1-M_N(1 <= M_i <= 1 ...
- 5. 支撑高并发,高可用,海量数据备份恢复的Redis重要性
商品详情页的架构实现 缓存架构 第一块儿,要掌握的很好的,就是redis架构 高并发,高可用,海量数据,备份,随时可以恢复,缓存架构如果要支撑这些要点,首先呢,redis就得支撑 redis架构,每秒 ...
- [转]Spark SQL2.X 在100TB上的Adaptive execution(自适应执行)实践
Spark SQL是Apache Spark最广泛使用的一个组件,它提供了非常友好的接口来分布式处理结构化数据,在很多应用领域都有成功的生产实践,但是在超大规模集群和数据集上,Spark SQL仍然遇 ...
- Flink 容错机制与状态
简介 Apache Flink提供了一种容错机制,可以持续恢复数据流应用程序的状态. 该机制确保即使出现故障,经过恢复,程序的状态也会回到以前的状态. Flink 主持 at least once 语 ...
- class(一)--类的创建
class是ES6引入的,它并不是一种全新的继承模式,而只是基于原型对象继承封装的语法糖,因此只要充分理解原型对象,原型链,继承等知识,class也就很好容易理解了 类的声明 ES5及之前是通过创建一 ...
- stl 题目总结
stl 题目总结 一.圆桌问题 1 .问题: 圆桌上围坐着2n个人.其中n个人是好人,另外n个人是坏人.如果从第一个人开始数数,数到第m个人,则立即处死该人:然后从被处死的人之后开始数数,再将数到的第 ...
- Tyvj1952 Easy
%%http://hzwer.com/2838.html 比较巧妙的是原来L^2->(l+1)^1=L^2+2*L+1这样就可以递推了 “?”的贡献及时“o”贡献的1/2. #include&l ...
- Vulkan SDK 之 Depth Buffer
深度缓冲是可选的,比如渲染一个3D的立方体的时候,就需要用到深度缓冲.Swapchain就算有多个images,此时深度缓冲区也只需要一个.vkCreateSwapchainKHR 会创建所有需要的i ...
- Atomic系列类整体介绍
本博客系列是学习并发编程过程中的记录总结.由于文章比较多,写的时间也比较散,所以我整理了个目录贴(传送门),方便查阅. 并发编程系列博客传送门 本文是转载文章,原文请见此博客,文章主要对java.ut ...