MySQL:如何从ibd文件中恢复数据(图文)
5909 点击·0 回帖
![]() | ![]() | |
![]() | 在使用独立表空间的情况下,如果不慎使得innodb存储引擎的元数据文件ibdata损坏,我们还可以挽救宝贵的数据.因为在innodb使用独立表空间的情况下,ibdata文件会记录每个innodb表的id,只要使得ibd中的表id和ibdata文件中记录的表id相同,就能够打开表,读取到数据. #创建表 CREATE TABLE `ibdtest` ( `id` int(11) NOT NULL AUTO_INCREMENT, `fid` int(11) NOT NULL COMMENT '表b中的id', `content` char(255) NOT NULL COMMENT '操作内容,系统生成', `mark` char(255) NOT NULL COMMENT '备注', PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 ![]() #添加数据 INSERT ibdtest (fid,content,mark) VALUES (1,'1','1'),(2,'2','2'); SELECT * FROM ibdtest; ![]() 关闭mysql将ibdtest.ibd copy出来,放到其他数据库中来模拟灾难. ![]() [root@localhost ~]#/opt/soft/mysql/bin/mysqladmin -p123456 shutdown 120130 18:31:50 mysqld_safe mysqld from pidfile /opt/soft/mysql/60137.localdomain.pid ended [1]+ Done /opt/soft/mysql/bin/mysqld_safe--defaults-file=/opt/soft/mysql/config/my.cnf --user=mysql [root@localhost ~]# cd /home/soft/mysql/data/test/ [root@localhost test]# ll total 1296 -rw-rw----. 1 mysql mysql 8612 Jan 18 00:06 a.frm -rw-rw----. 1 mysql mysql 98304 Jan 18 00:24 a.ibd -rw-rw----. 1 mysql mysql 8624 Jan 30 08:34 area.frm -rw-rw----. 1 mysql mysql 98304 Jan 30 08:36 area.ibd -rw-rw----. 1 mysql mysql 8642 Jan 18 00:05 b.frm -rw-rw----. 1 mysql mysql 98304 Jan 18 00:08 b.ibd -rw-rw----. 1 mysql mysql 8693 Jan 30 18:27 ibdtest.frm -rw-rw----. 1 mysql mysql 98304 Jan 30 18:28 ibdtest.ibd -rw-rw----. 1 mysql mysql 8728 Jan 6 16:23 testa.frm -rw-rw----. 1 mysql mysql 98304 Jan 10 04:10 testa.ibd -rw-rw----. 1 mysql mysql 8693 Jan 30 14:30 testmc.frm -rw-rw----. 1 mysql mysql 98304 Jan 30 14:30 testmc.ibd -rw-rw----. 1 mysql mysql 8693 Jan 30 13:54 testme.frm -rw-rw----. 1 mysql mysql 98304 Jan 30 13:55 testme.ibd -rw-rw----. 1 mysql mysql 8693 Jan 30 14:40 testmm.frm -rw-rw----. 1 mysql mysql 98304 Jan 30 14:45 testmm.ibd -rw-rw----. 1 mysql mysql 8693 Jan 30 13:40 testmu.frm -rw-rw----. 1 mysql mysql 98304 Jan 30 13:40 testmu.ibd -rw-rw----. 1 mysql mysql 8693 Jan 30 11:08 testmv.frm -rw-rw----. 1 mysql mysql 98304 Jan 30 11:10 testmv.ibd -rw-rw----. 1 mysql mysql 8694 Jan 4 21:55 testuser.frm -rw-rw----. 1 mysql mysql 98304 Jan 4 22:04 testuser.ibd -rw-rw----. 1 mysql mysql 8644 Jan 14 21:55 user.frm -rw-rw----. 1 mysql mysql 98304 Jan 14 21:55 user.ibd [root@localhost test]# cp ibdtest.ibd /home/download/ [root@localhost test]# cd /home/download/ #vim打开ibd,使用16进制查看 [root@localhost download]# vim -b ibdtest.ibd :%!xxd 从下图中能看到 此表在 当前mysql数据库中的id为0x10,即16. ![]() 此时,我们假设灾难发生,ibdata损坏… 只剩下了ibdtest.ibd文,我们跳转到另一个mysql服务器上,用同样的建表语句创建ibdtest表. ![]() 这时我们打开这个mysql服务器下的ibdtest.ibd看看: ![]() 这个表的id为0x16,即为22,那么,我们只需将原有的ibdtest.ibd表id修改为0x16即可. ![]() 退出保存的时候一定要记得使用:%!xxd -r 退出保存. 并将修改好的文件覆盖掉新的ibdtest.ibd即可, ![]() 此mysql服务器会认为该表损毁,无法打开,没关系,修改innodb_force_recovery = 6, ![]() 重启mysql服务: ![]() Select下,就知道数据是否恢复了没有: ![]() 此时,无法执行写操作,应尽快将数据dump出来,修改innodb_force_recovery = 0,重启服务,创建新表后,把数据倒回去就ok了.恢复数据就不演示了. ![]() | |
![]() | ![]() |