700字范文,内容丰富有趣,生活中的好帮手!
700字范文 > 无全量备份 未开启binlog日志 利用percona工具恢复delete的数

无全量备份 未开启binlog日志 利用percona工具恢复delete的数

时间:2020-07-22 06:53:58

相关推荐

无全量备份 未开启binlog日志 利用percona工具恢复delete的数

数据库|mysql教程

无全,备份,开启,binlog,日志,利用,percona,

数据库-mysql教程

bs架构源码,vscode c语言头文件,ubuntu中联网,tomcat监控的质量,美国爬虫协会,时间插件 php,韶关关键词seo,校园商品配送网站源码,摄影大赛源码模板lzw

当我们忘记做全量备份时,并且没有开启binlog,并执行了 deletefromsbtest; 数据全部丢失,要想恢复是很有难度的。 今天,利用Percona Data Recovery Tool for InnoDB工具 (仅支持InnoDB,MyISAM不支持) ,可以找回被删除的数据。 原理:在InnoDB引擎,del

捕鱼源码下载,vscode runner,ubuntu mailx,tomcat装备,sqlite查询容量,域名服务器的类型有,echarts地图插件,前端框架 饼图,java 爬虫工具,php提取字符串中的数字,Seo曾辉,个人业务网站建设,爱情表白网页模板,薇晓朵极简手机模板,淘宝支付页面html模板,delphi图书馆管理系统,微信小程序 开源代码lzw

QQ代刷网源码带分站,ubuntu cpu已关闭,无法运行Tomcat的原因,scratch和爬虫,php两个问好,seo运营员怎么招seo顾问lzw

当我们忘记做全量备份时,并且没有开启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不能恢复(数据文件都没了,还怎么恢复?)。

A、安装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

# cd percona-data-recovery-tool-for-innodb-0.5/mysql-source# ./configure# cd ..# make

B、全表删除sbtest表

delete from sbtest;

C、恢复

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

650) this.width=650;” src=”///uploads/allimg/151213/0K23452I-0.jpg” alt=”无全量备份、未开启binlog日志,利用percona工具恢复delete的数” title=”无全量备份、未开启binlog日志,利用percona工具恢复delete的数” />

650) this.width=650;” src=”///uploads/allimg/151213/0K23430J-1.jpg” alt=”无全量备份、未开启binlog日志,利用percona工具恢复delete的数” title=”无全量备份、未开启binlog日志,利用percona工具恢复delete的数” />

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

650) this.width=650;” src=”///uploads/allimg/151213/0K23422N-2.jpg” alt=”无全量备份、未开启binlog日志,利用percona工具恢复delete的数” title=”无全量备份、未开启binlog日志,利用percona工具恢复delete的数” />

650) this.width=650;” src=”///uploads/allimg/151213/0K23411X-3.jpg” alt=”无全量备份、未开启binlog日志,利用percona工具恢复delete的数” title=”无全量备份、未开启binlog日志,利用percona工具恢复delete的数” />

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

650) this.width=650;” src=”///uploads/allimg/151213/0K234J29-4.jpg” alt=”无全量备份、未开启binlog日志,利用percona工具恢复delete的数” title=”无全量备份、未开启binlog日志,利用percona工具恢复delete的数” />

在这里,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

650) this.width=650;” src=”///uploads/allimg/151213/0K23422X-5.jpg” alt=”无全量备份、未开启binlog日志,利用percona工具恢复delete的数” title=”无全量备份、未开启binlog日志,利用percona工具恢复delete的数” />

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命令查看)

650) this.width=650;” src=”///uploads/allimg/151213/0K2344G4-6.jpg” alt=”无全量备份、未开启binlog日志,利用percona工具恢复delete的数” title=”无全量备份、未开启binlog日志,利用percona工具恢复delete的数” />

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

执行完毕,如下图:

650) this.width=650;” src=”///uploads/allimg/151213/0K2345916-7.jpg” alt=”无全量备份、未开启binlog日志,利用percona工具恢复delete的数” title=”无全量备份、未开启binlog日志,利用percona工具恢复delete的数” />

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

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

650) this.width=650;” src=”///uploads/allimg/151213/0K2344052-8.jpg” alt=”无全量备份、未开启binlog日志,利用percona工具恢复delete的数” title=”无全量备份、未开启binlog日志,利用percona工具恢复delete的数” />

5、导入到表里

LOAD DATA INFILE /tmp/sbtest.txt REPLACE INTO TABLE `sbtest` FIELDS TERMINATED BY \ OPTIONALLY ENCLOSED BY \" LINES STARTING BY sbtest\t (id, k, c, pad);

650) this.width=650;” src=”///uploads/allimg/151213/0K2343513-9.jpg” alt=”无全量备份、未开启binlog日志,利用percona工具恢复delete的数” title=”无全量备份、未开启binlog日志,利用percona工具恢复delete的数” />

总结:

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

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。