热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

mysql没开启binlog恢复删除表_无全量备份、未开启binlog日志,利用percona工具恢复delete的数据...

当我们忘记做全量备份时,并且没有开启binlog,并执行了deletefromsbtest;数据全部丢失,要想恢复是很有难度的。今天&#x

当我们忘记做全量备份时,并且没有开启binlog,并执行了delete from sbtest;

数据全部丢失,要想恢复是很有难度的。

今天,利用Percona Data Recovery Tool for InnoDB工具(仅支持InnoDB,MyISAM不支持),可以找回被删除的数据。

原理:在InnoDB引擎,delete删除操作,不是真正的删除物理文件上的行,而是增加一个删除的标记,我们都用过WORD吧?在修改字体的时候,有一个删除线的标记,如《MySQL 管理之道》,该工具利用这个特性,找回那些标注了删除线的数据,并存入到一个文本里,然后通过load data命令,批量插入到表里。

注:truncate不能恢复(truncate是直接清空数据行,并不是添加删除标记,你可以通过查看物理文件,执行了truncate操作,ibd文件变小,而执行了delete操作,ibd文件还跟之前的一样大),drop不能恢复(数据文件都没了,还怎么恢复?)。

一、安装Percona Data Recovery Tool for InnoDB工具# cd percona-data-recovery-tool-for-innodb-0.5/mysql-source

# ./configure

# cd ..

# make

二、全表删除sbtest表delete from sbtest;

三、恢复

1、提取ibd物理文件,按照每页16K,单独存放。# cd percona-data-recovery-tool-for-innodb-0.5/

# ./page_parser -5 -f /usr/local/mysql-5.5.37/data/test/sbtest.ibd

22dfbb9a5f2f4900c574a780ccb81b99.png

59f1092fa0c298bbd1649f8d1de9395b.png

会在当前目录生成一个pages-1410414511目录(后面的数字是变化的,在你的机器上会跟我的不同)

142c3f570e514bc0cfd7b5a15ab2ae2a.png

306123f01a2b4da46e1c14a85ec09b36.png

在FIL_PAGE_INDEX目录下面,会生成主键和索引,数据最小的是主键,后面依次是每个列的索引

67fa923ef397cab83031d9faa13cb860.png

在这里,0-28是sbtest表的主键(id),0-29是sbtest表的索引(k)。记住这个目录数字,后面我们需要通过这个目录恢复数据。

2、生成表结构# cd percona-data-recovery-tool-for-innodb-0.5/

# ./create_defs.pl --host localhost --port 3306 --user root --password 123456 --db test --table sbtest > include/table_defs.h

-- host 主机地址

-- port 端口

-- user 用户名

-- password 密码

-- db 数据库名

-- table 表名

3、再次执行make编译命令# cd percona-data-recovery-tool-for-innodb-0.5/

# make

5dc9fd1678d4874a25b5a1945def4d11.png

4、恢复删除的数据# cd percona-data-recovery-tool-for-innodb-0.5/

# ./constraints_parser -D -5 -f pages-1410414511/FIL_PAGE_INDEX/0-28/ > /tmp/sbtest.txt

-D 恢复删除的行

-5 表的文件格式,默认是Compact

(不清楚的朋友,可以用show table status命令查看)

fed97aa541fa5037371a863fe7881486.png

-f 指定生成sbtest表的主键目录

执行完毕,如下图:

8093e29e7c94815a09312628dcba232f.png

会自动生成一个load data infile命令,请把这个复制下来,一会我们要导入数据。

在/tmp目录下,会生成sbtest.txt,我们就要用这个文件做恢复。

3a175df44b6b7e3fb270e8c1bae00f93.png

5、导入到表里LOAD DATA INFILE '/tmp/sbtest.txt' REPLACE INTO TABLE `sbtest` FIELDS TERMINATED BY '\t' OPTIONALLY ENCLOSED BY '"' LINES STARTING BY 'sbtest\t' (id, k, c, pad);

792955bdbd5a026955d10890613df8c3.png

总结:

通过上述方法,顺利的完成了delete数据恢复。在数据被删除后,切记要备份ibd数据文件,一定不要覆盖,否则都是不能完成修复的。目前该工具不支持字符串set类型。



推荐阅读
author-avatar
落墨
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有