mysql5.6之 传输表空间迁移表或恢复误删除的表

本文涉及的产品
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
简介:

一,简单说明:

1),传输表空间的限制:
  1,mysql 版本 5.6.6 及其以上,并且版本建议源和目标版本建议都是GA版并且大版本一样
  2,表引擎为innodb并且开启独立表空间  innodb_file_per_table
  3,处于导出状态的表只允许读也即是”read_only“状态
  4,DISCARD TABLESPACE不支持分区表[5.6.17才支持] 并且当表上具有外键关系的时候需要将 foreign_key_check设置为0
  5,源和目标实例的page size 必须大小一致
  6,ALTER TABLE ... IMPORT TABLESPACE  不强制进行外键约束检查,所以需要将主表和子表都导出,然后在目标实例导入,
     另外该操作不需要.cfg 元数据文件,当然如果没有改文件在导入的时候是不做元数据检查的
  7,在windows上,innodb引擎内部都是以小写格式存储数据库,表名和表空间名,故为了避免导入因为大小写出现文件建议在大小写敏感, 如linux、unix的操作系统上都以小写的格式创建数据库和表同时在[mysqld]项下 添加
      [mysqld]
      lower_case_table_names=1 
      
2),传输表空间的优点:
  1,不需要消耗太多的资源
  2,很方便的将表 从一个实例迁移到另一个实例
  3,相对于mysqldump来说你无须导出然后导入同时还的维护索引


二,正常的表空间迁移
     1, 源数据库:
          use test;
          create table lidan(id int) engine=innodb;
          insert into lidan values(10);
     2,目标数据库:
          use test;
          create table lidan(id int) engine=innodb;
          insert into lidan values(10); 
     3,目标数据库卸载表空间:
         ALTER TABLE lidan DISCARD TABLESPACE;
         卸载表空间后lidan.ibd 文件和表空间分离并且会对表加一个排他锁,此时如果执行dml则会直接报错如图:
           
     4,源数据执行表空间导出:
         use test;
         FLUSH TABLES lidan FOR EXPORT;
        flush操作会触发表lidan的dirty page刷新到磁盘,并且stop purge 线程,同时将元数据信息写入lidan.cfg 如图:
          
        元数据文件存储的信息如下:
          
         主要就是一些数据库和表名、row_id 、回滚指针、事物id等 
        该会话会一直持有表lidan的metadata锁,故此时其他会话只能进行SELECT二更新和插入操作会被阻塞 。
        如图:
         
        
     5,将导出的表(源数据库)所在数据文件目录下对应的lidan.ibd file和lidan.cfg 拷贝到目标数据库对应的文件夹下
        cp -p  lidan.cfg lidan.ibd /data/percona-data-3307/test/ 
         
        注意:文件的拷贝必须在下一步释放metadata lock 之前
     6,释放源数据库的metadata lock
         use test;
         unlock table;
        unlock 这一步会删除之前生成的lidan.cfg文件,同时释放metadata lock 并且重新启动purge 线程
     7,目标数据库将表导入到表空间
        alter table lidan import tablespace; 
        然后查看导入成功如图:
         
        导入的过程mysql内部会做如下事情:
        a,检查表空间每个page的一致性
        b,更新每个page的space id和lsn的信息
        c,启用头部页标记和更新LSN到头部页
        d,page 状态信息设置为dirty ,这样page将很快会被刷新到磁盘
       具体如图
                 
三,误删除情况下的恢复
    这里只讨论备库误删除的恢复,如果是主库误删表那只能通过备份来恢复了
     1,首先备库上执行drop操作,模拟误删除
       (user:root  time: 16:37 port: 3307)[db: test]drop table lidan;
     2,备库恢复必须要有.frm文件,故这里需要从源库查看表结构然后在目标库创建
        create table lidan(id int) engine=innodb;  
     接下来的步骤就按照(二)当中从3开始做即可,具体请自行测试。
 
    
参考:
http://dev.mysql.com/doc/refman/5.6/en/flush.html                                                        
http://dev.mysql.com/doc/refman/5.6/en/tablespace-copying.html

转:http://blog.csdn.net/lidan3959/article/details/25152623


本文转自 张冲andy 博客园博客,原文链接: http://www.cnblogs.com/andy6/p/6940883.html  ,如需转载请自行联系原作者


相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
相关文章
|
存储 关系型数据库 MySQL
第9章 【MySQL】InnoDB的表空间
第9章 【MySQL】InnoDB的表空间
256 0
第9章 【MySQL】InnoDB的表空间
|
8月前
|
关系型数据库 MySQL Linux
在Linux环境下备份Docker中的MySQL数据并传输到其他服务器以实现数据级别的容灾
以上就是在Linux环境下备份Docker中的MySQL数据并传输到其他服务器以实现数据级别的容灾的步骤。这个过程就像是一场接力赛,数据从MySQL数据库中接力棒一样传递到备份文件,再从备份文件传递到其他服务器,最后再传递回MySQL数据库。这样,即使在灾难发生时,我们也可以快速恢复数据,保证业务的正常运行。
403 28
|
存储 关系型数据库 MySQL
MySQL表空间结构与页、区、段的定义
一、概念引入 1、页 InnoDB是以页为单位管理存储空间的,在InnoDB中针对不同的目的设计了各种不同类型的页面。如下(省略了FIL_PAGE或FiL_PAGE_TYPE的前缀):
|
存储 监控 关系型数据库
MySQL造数据占用临时表空间
MySQL造数据占用临时表空间
245 0
|
存储 关系型数据库 MySQL
MySQL数据库——InnoDB引擎-逻辑存储结构(表空间、段、区、页、行)
MySQL数据库——InnoDB引擎-逻辑存储结构(表空间、段、区、页、行)
504 7
|
自然语言处理 监控 关系型数据库
mysql造数据占用临时表空间
【5月更文挑战第20天】MySQL在处理复杂查询时可能使用临时表,可能导致性能下降。临时表用于排序、分组和连接操作。常见问题包括内存限制、未优化的查询、数据类型不当和临时表清理。避免过度占用的策略包括优化查询、调整系统参数、优化数据类型和事务管理。使用并行查询、分区表和监控工具也能帮助管理临时表空间。通过智能问答工具如通义灵码,可实时续写SQL和获取优化建议。注意监控`Created_tmp_tables`和`Created_tmp_disk_tables`以了解临时表使用状况。
810 5
|
存储 关系型数据库 MySQL
9.3 【MySQL】系统表空间
9.3 【MySQL】系统表空间
247 0
|
存储 SQL 关系型数据库
面试官:mysql 表删除一半数据,表空间会变小吗?
这期面试官提的问题是: MySQL 表删除一半数据,表空间是否会变小?为什么?
|
存储 缓存 关系型数据库
Mysql专栏 - 缓冲池补充、数据页、表空间简述
Mysql专栏 - 缓冲池补充、数据页、表空间简述
227 0

推荐镜像

更多