Innodb 表空间传输迁移数据
在mysql5.5之前,mysql实例中innodb引擎表的迁移是个头疼的问题,要么使用mysqldump导出,要么使用物理备份的方法,但是在mysql5.6之后的版本中,可以使用一个新特性,方便地迁移Innodb表,这样一来大的innodb表的迁移就显得很easy,这个特性就是innodb表空间传输:
1.在迁出实例数据库:
mysql> use xiaoboluo;
mysql> select * from test1; #查询一下迁出实例表数据,这里是测试表,大表请不要这么干
+------------+-------+-------------+
| product_id | param | create_time |
+------------+-------+-------------+
| 1 | 1 | 1 |
| 10 | 10 | 10 |
| 11 | 1 | 1 |
| 12 | 100 | 101 |
| 13 | 101 | 101 |
| 14 | 100 | 101 |
| 2 | 2 | 2 |
| 3 | 3 | 3 |
| 4 | 4 | 4 |
| 5 | 5 | 5 |
| 6 | 6 | 6 |
| 7 | 7 | 7 |
| 8 | 8 | 8 |
| 9 | 9 | 9 |
+------------+-------+-------------+
14 rows in set (0.00 sec)
mysql> show create table test1; #查看表定义语句,复制出来
2.在迁入实例数据库:
mysql> create database xiaoboluo;
建表:
mysql> use xiaoboluo
mysql> CREATE TABLE `test1` (
`product_id` varchar(50) NOT NULL,
`param` int(11) DEFAULT NULL,
`create_time` int(11) DEFAULT NULL,
PRIMARY KEY (`product_id`),
KEY `i_create_time` (`create_time`),
KEY `i_product_create_time` (`product_id`,`create_time`),
KEY `i_param` (`param`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
查看表相关文件:
shell > ll /data/mysql3306/xiaoboluo/test1*
-rw-rw---- 1 mysql mysql 8648 1月 7 09:31 /data/mysql3306/xiaoboluo/test1.frm
-rw-rw---- 1 mysql mysql 147456 1月 7 09:33 /data/mysql3306/xiaoboluo/test1.ibd
mysql> alter table test1 discard tablespace; #注意再三确认这个命令有没有搞错对象,一执行就会把ibd文件给删掉
再次查看表相关文件,可以看到没有了表空间文件ibd:
shell > ll /data/mysql3306/xiaoboluo/test1*
-rw-rw---- 1 mysql mysql 8648 1月 7 09:37 /data/mysql3306/xiaoboluo/test1.frm
3.在迁出实例数据库:
mysql> use xiaoboluo;
mysql> flush tables test1 for export; #这个时候会加表锁,只能读不能写,同时也会产生一个tb_name.cfg文件
然后复制这个表的ibd和cfg文件到迁入实例的新建同名库目录下:
shell > scp /data/mysql3306/xiaoboluo/test1.{cfg,ibd} 192.168.0.37:/data/mysql3306/xiaoboluo
root@192.168.0.37's password:
test1.cfg 100% 801 0.8KB/s 00:00
test1.ibd 100% 144KB 144.0KB/s 00:00
mysql> unlock tables; #解锁迁出实例表
4.在迁入目标实例上:
mysql> use xiaoboluo;
shell > chown mysql.mysql /data/mysql3306/xiaoboluo/test1.{ibd,cfg}
查看文件权限:
shell > ll /data/mysql3306/xiaoboluo/test1*
-rw-r----- 1 mysql mysql 801 1月 7 09:40 /data/mysql3306/xiaoboluo/test1.cfg
-rw-rw---- 1 mysql mysql 8648 1月 7 09:37 /data/mysql3306/xiaoboluo/test1.frm
-rw-r----- 1 mysql mysql 147456 1月 7 09:41 /data/mysql3306/xiaoboluo/test1.ibd
mysql> Alter table test1 import tablespace; #导入表空间文件
mysql> select * from test1; #校验数据是否正常,这里是测试表,大表请用其他方法验证数据
+------------+-------+-------------+
| product_id | param | create_time |
+------------+-------+-------------+
| 1 | 1 | 1 |
| 10 | 10 | 10 |
| 11 | 1 | 1 |
| 12 | 100 | 101 |
| 13 | 101 | 101 |
| 14 | 100 | 101 |
| 2 | 2 | 2 |
| 3 | 3 | 3 |
| 4 | 4 | 4 |
| 5 | 5 | 5 |
| 6 | 6 | 6 |
| 7 | 7 | 7 |
| 8 | 8 | 8 |
| 9 | 9 | 9 |
+------------+-------+-------------+
14 rows in set (0.00 sec)
到这里整个innodb表就被迁移完成,是不是比以前的方法方便很多呢!!
Innodb 表空间传输迁移数据的更多相关文章
- EXPDP/IMPDP与EXP/IMP在不同用户和表空间之间迁移数据的实现方法
1. EXPDP/IMPDP方式 SQL> create user zlm identified by zlm; User created. SQL> grant connect,reso ...
- [20170623]利用传输表空间恢复部分数据.txt
[20170623]利用传输表空间恢复部分数据.txt --//昨天我测试使用传输表空间+dblink,上午补充测试发现表空间设置只读才能执行impdp导入原数据,这个也很好理解.--//这样的操作模 ...
- MySQL 表空间传输
聊到MySQL数据迁移的话题,表空间传输时一个很实用的方法. 在MySQL 5.6 Oracle引入了一个可移动表空间的特征(复制的表空间到另一个服务器)和Percona Server采用部分备份,这 ...
- Oracle表空间传输测试
源数据库平台:window 7 64bit Oracle 11g 64bit目标数据库平台:RHEL6 64bit Oracle 11g 64bit 1.查看数据集 select * from nls ...
- Oracle11gR2导入导出实战之表空间传输
Oracle11gR2导入导出实战之使用Datapump进行表空间传输 表空间检查 [oracle@localhost database]$ ps -ef|grep smon oracle 8981 ...
- MySQL Innodb表空间不足的处理方法
官方给出的解决方案: 添加和删除 InnoDB 数据和日志文件 这一节描述在InnoDB表空间耗尽空间之时,或者你想要改变日志文件大小之时,你可以做的一些事情. 最简单的,增加InnoDB表空间大小的 ...
- ibd2sdi — InnoDB表空间SDI提取实用程序
参考mysql8.0官方文档 https://dev.mysql.com/doc/refman/8.0/en/ibd2sdi.html ibd2sdi是一个实用程序,用于从表空间文件中提取 序列化的字 ...
- MySQL InnoDB表空间加密
从 MySQL5.7.11开始,MySQL对InnoDB支持存储在单独表空间中的表的数据加密 .此功能为物理表空间数据文件提供静态加密.该加密是在引擎内部数据页级别的加密手段,在数据页写入文件系统时加 ...
- Oracle创建删除用户,角色,表空间,导入导出数据库命令总结(转载)
无意间看到一篇文章,觉得对于ORACLE的新手很实用,特转载,原文出处这里 说明:在创建数据库时输入的密码,是修改系统默认的密码,以system和sysman等系统默认身份登录时要输入的密码就是修改后 ...
随机推荐
- Eclipse导入现有项目
针对一些新手内容 1.Eclipse 打开一个项目 第一步File-->Import导入 第二步:选择导入类型 第三步选择文件路径,点击Browse... 注意下面细红框选项,根据需要勾选 第四 ...
- 《UML大战需求分析》阅读笔记04
在学习了前面的几种UML图并不能满足所有情况的建模,如当流程图涉及到多种角色,并且通过对多种角色交互展开时,顺序图才是不二选择.顺序图就如同中文语法的说话语言相似,描述的是一种事件发生的顺序.顺序图分 ...
- android模拟器没有键盘的解决方法
刚开始使用android模拟器的时候,发现自己创建的AVD启动后没有出现侧边的键盘,在网上搜索后,发现很多人都有这个问题,也有文章说直接使用PC上的键盘,因为有对应的快捷键.但是,没有键盘,始终不爽! ...
- Java读写资源文件类Properties
Java中读写资源文件最重要的类是Properties 1) 资源文件要求如下: 1.properties文件是一个文本文件 2.properties文件的语法有两种,一种是注释,一种属性配置. 注 ...
- GIT使用笔记-fatal:multiple stage entries for merged file处理办法
该错误是在cherry-pick时出现 无法确定冲突原因 分支无法checkout ,reset等等全都失效 在网上给出的解决办法全部都是 rm .git/index git add -A git c ...
- netstrem获取302后的地址,可用来截图,加载实际跨域文件
直接放代码,老外博客看来的,老外还是牛逼,这都用出来了:http://jessewarden.com/2009/03/handling-crossdomainxml-and-302-redirects ...
- Hibernate操作指南-实体之间的关联关系(基于注解)
- Unity 编译apk启动出异常
问题:unity 编译出来的apk,在android安装启动,时报以下错误: 07-06 20:52:48.282: E/linker(18229): load_library(linker.cpp: ...
- php登陆与注册
登陆页面 <body><h1>登录页面</h1><form action="./dengluchuli.php" method=" ...
- Url获取图片流并打包~
因为公司项目需求,做一个所有数据以excle的格式汇出,其中包括了图片. 而数据库保存的是图片的url,虽然不知道为什么....如果数据量大的话, 那么所有数据汇出,包括图片的话... 额.. 不知道 ...