2014年9月16日星期二

TMG 2010 建立站对站VPN隧道

本邮件内容由第三方提供,如果您不想继续收到该邮件,可 点此退订
TMG 2010 建立站对站VPN隧道  阅读原文»

TMG 2010 建立站对站VPN隧道
返回顶部

无全量备份、未开启binlog日志,利用percona工具恢复delete的数据  阅读原文»

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

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

deletefromsbtest;

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

今天,利用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 https://launchpad.net/percona-data-recovery-tool-for-innodb/trunk/release-0.5/+download/percona-data-recovery-tool-for-innodb-0.5.tar.gz

#cdpercona-data-recovery-tool-for-innodb-0.5/mysql-source

二、全表删除sbtest表

deletefromsbtest;

三、恢复

1、提取ibd物理文件,按照每页16K,单独存放。

#cdpercona-data-recovery-tool-for-innodb-0.5/
#./page_parser-5-f/usr/local/mysql-5.5.37/data/test/sbtest.ibd

wKioL1QWjBbQtR24AAcTs4jETjo710.jpg

wKioL1QWjBfQ5v4eAAMOU75u5yE417.jpg

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

wKioL1QWjNeRc1gzAAGi--J2QzM705.jpg

wKiom1QWjUXSIuLRAAjqU2V4Rmk266.jpg

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

wKioL1QWjcfTyYIVAACR8hnJJ78355.jpg

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

2、生成表结构

#cdpercona-data-recovery-tool-for-innodb-0.5/
#./create_defs.pl--hostlocalhost--port3306--userroot--password123456--dbtest--tablesbtest>include/table_defs.h

-- host 主机地址

-- port 端口

-- user 用户名

-- password 密码

-- db 数据库名

-- table 表名

3、再次执行make编译命令

#cdpercona-data-recovery-tool-for-innodb-0.5/

wKiom1QWj3nzmDC0AAUbkA6b0jc746.jpg

4、恢复删除的数据

#cdpercona-data-recovery-tool-for-innodb-0.5/
#./constraints_parser-D-5-fpages-1410414511/FIL_PAGE_INDEX/0-28/>/tmp/sbtest.txt

-D 恢复删除的行

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

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

wKioL1QWkRiDTihIAAI9NJg8fOQ199.jpg

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

执行完毕,如下图:

wKiom1QWknDBeZOHAAIWMrwbsBE715.jpg

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

?p>阅读更多内容

没有评论:

发表评论