- 1、本文档共5页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
无全量备份、未开启binlog日志,利用percona工具恢复delete的数据今天,利用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工具 #?wget? /percona-data-recovery-tool-for-innodb/trunk/release-0.5/+download/percona-data-recovery-tool-for-innodb-0.5.tar.gz/percona-data-recovery-tool-for-innodb/trunk/release-0.5/+download/percona-data-recovery-tool-for-innodb-0.5.tar.gz 二、全表删除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会在当前目录生成一个pages-1410414511目录(后面的数字是变化的,在你的机器上会跟我的不同)在FIL_PAGE_INDEX目录下面,会生成主键和索引,数据最小的是主键,后面依次是每个列的索引在这里,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/# make4、恢复删除的数据 # cd percona-data-recovery-tool-for-innodb-0.5/# ./constraints_parser -D -5 -f pages-1410414511/FIL_PAGE_INDEX/0-28/ /tmp/sbtest.txtD?恢复删除的行-5?表的文件格式,默认是Compact(不清楚的朋友,可以用show?table?status命令查看)-f?指定生成sbtest表的主键目录执行完毕,如下图:会自动生成一个load?data?infile命令,请把这个复制下来,一会我们要导入数据。在/tmp目录下,会生成sbtest.txt,我们就要用这个文件做恢复。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);总 结: 通过上述方法,顺利的完成了delete数据恢复。在数据被删除后,切记要备份ibd数据文件,一定不要覆盖,否则都是不能完成修复的。目前该工具不支持字符串set类型。来自: /5223301/1552917/5223301/1552917
文档评论(0)