亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > 文庫 > 正文

由percona-data-recovery-tool恢復ibd數據的工具的一些測試

2024-09-07 22:12:43
字體:
來源:轉載
供稿:網友
        無意間看到了percona-data-recovery-tool 這個工具,這個工具是用來恢復innodb數據文件中的數據,貌似都建議row_format必須是REDUNDANT或者COMPACT。而在mysql5.7.8以上默認為Dynamic,但其實在此處我在Dynamic下測試是沒有問題的。
 
        當我們誤刪除某個表數據時,實際上數還存留在數據文件中,因此可通過特殊手段從數據文件中抽取相應的數據。
 
         數據被誤刪除后,需要盡快將保護現場,停止數據庫,把 idb 文件拷貝出來,防止 ibd 文件寫入數據被覆蓋。
 
安裝方法:
 
https://launchpadlibrarian.net/78359944/percona-data-recovery-tool-for-innodb-0.5.tar.gz
 
yum install glibc-static
 
yum -y install perl-DBD-MySQL.x86_64
 
tar -xf percona-data-recovery-tool-for-innodb-0.5.tar.gz
 
cd percona-data-recovery-tool-for-innodb-0.5
 
cd mysql-source/
 
./configure
 
cd ..
 
make
 
解析 ibd 文件:此處會將ibd文件以16k為單位分割成n個文件
 
./page_parser -5 -f /home/mysql/datal/cwdtest/card.ibd  
 
參數解釋:
 
-5:代表 row format 為 Compact
 
-f:代表要解析的文件,innodb的ibd文件
 
[root@xxxx-sql-auditing percona-data-recovery-tool-for-innodb-0.5]# ./page_parser -5 -f /home/mysql/datal/cwdtest/card.ibd
Opening file: /home/mysql/datal/cwdtest/card.ibd:
64769 ID of device containing file
189843585 inode number
33184 protection
1 number of hard links
1001 user ID of owner
1001 group ID of owner
0 device ID (if special file)
9437184 total size, in bytes
4096 blocksize for filesystem I/O
18432 number of blocks allocated
1543312312 time of last access
1543394915 time of last modification
1543394915 time of last status change
9437184 Size to process in bytes
104857600 Disk cache size in bytes
83.25% done. 2018-11-28 16:52:19 ETA(in 00:00 hours). Processing speed: 7856357 B/sec
生成表定義
 
./create_defs.pl -host 127.0.0.1 -port 3306 -user root -password mysql123 -db cwdtest -table card >include/table_defs.h
 
make
 
開始恢復 pages 中刪除的數據:
 
./constraints_parser -5 -D -f ./pages-1543395138/FIL_PAGE_INDEX/0-602/22-00000025.page >/tmp/22-00000025.page.txt
 
參數:
 
-5 -f 的參數和 page_parser 相同;
 
-D:該參數的含義為代表恢復刪除的數據頁;
 
[root@xxxx-sql-auditing percona-data-recovery-tool-for-innodb-0.5]# ./constraints_parser -5 -D -f ./pages-1543395138/FIL_PAGE_INDEX/0-602/40-00000071.page >/tmp/00000071.sql
LOAD DATA INFILE '/usr/local/src/percona-data-recovery-tool-for-innodb-0.5/dumps/default/SYS_TABLES' REPLACE INTO TABLE `SYS_TABLES` FIELDS TERMINATED BY '/t' OPTIONALLY ENCLOSED BY '"' LINES STARTING BY 'SYS_TABLES/t' (NAME, ID, N_COLS, TYPE, MIX_ID, MIX_LEN, CLUSTER_NAME, SPACE);
[root@xxxx-sql-auditing percona-data-recovery-tool-for-innodb-0.5]#
'
然后生成的文件就用load data 方式插入,其實該方法介紹的文章很多,這里只給出關鍵步驟。而對于在誤刪數據后是否數據還真的存于ibd中,我這里做個小小實驗。
 
表中有三行數據,刪除其中hhhhhhh一行。
 
mysql> select * from test;
+----------+----------+
| col1     | col2     |
+----------+----------+
|          | aaaaaaaa |
| ccccccc  | NULL     |
| hhhhhhhh | xxxxxxxx |
+----------+----------+
3 rows in set (0.00 sec)
mysql> delete from test where col1='hhhhhhhh';
Query OK, 1 row affected (0.01 sec)
用hexdump來查看ibd文件:
 
查看頁結構:
python py_innodb_page_info.py -v /data/mysql/cwdtest/test.ibd
page offset 00000000, page type <File Space Header>
page offset 00000001, page type <Insert Buffer Bitmap>
page offset 00000002, page type <File Segment inode>
page offset 00000003, page type <B-tree Node>, page level <0000>
page offset 00000000, page type <Freshly Allocated Page>
page offset 00000000, page type <Freshly Allocated Page>
Total number of page: 6:
Freshly Allocated Page: 2
Insert Buffer Bitmap: 1
File Space Header: 1
B-tree Node: 1
File Segment inode: 1
對該表數據文件做個hexdump:
 
hexdump -C -v  /data/mysql/cwdtest/test2.ibd >/tmp/udb.txt
 
page type <B-tree Node>, page level <0000> 從第四個頁開始,從hexdump中可找到相應的位置0x0000c000開始,16k*3=49152=0x0000c000
 
0000c000  8c 69 ae 6a 00 00 00 03  ff ff ff ff ff ff ff ff  |.i.j............|
0000c010  00 00 00 00 00 29 6a a5  45 bf 00 00 00 00 00 00  |.....)j.E.......|
0000c020  00 00 00 00 00 21 00 02  00 e7 80 05 00 00 00 00  |.....!..........|
0000c030  00 c4 00 02 00 00 00 03  00 00 00 00 00 00 00 00  |................|
0000c040  00 00 00 00 00 00 00 00  00 33 00 00 00 21 00 00  |.........3...!..|
0000c050  00 02 00 f2 00 00 00 21  00 00 00 02 00 32 01 00  |.......!.....2..|
0000c060  02 00 1d 69 6e 66 69 6d  75 6d 00 04 00 0b 00 00  |...infimum......|
0000c070  73 75 70 72 65 6d 75 6d  08 00 00 00 00 10 00 22  |supremum......."|
0000c080  00 00 00 00 02 0d 00 00  00 00 0b 36 ab 00 00 01  |...........6....|
0000c090  22 01 10 61 61 61 61 61  61 61 61 07 01 00 00 18  |"..aaaaaaaa.....|
0000c0a0  00 22 00 00 00 00 02 0e  00 00 00 00 0b 37 ac 00  |."...........7..|
0000c0b0  00 01 23 01 10 63 63 63  63 63 63 63 08 08 00 20  |..#..ccccccc... |
0000c0c0  00 20 ff ac 00 00 00 00  02 0f 00 00 00 00 0b a1  |. ..............|
0000c0d0  76 00 00 01 72 01 10 68  68 68 68 68 68 68 68 78  |v...r..hhhhhhhhx|<<<<<<<<<<
0000c0e0  78 78 78 78 78 78 78 00  00 00 00 00 00 00 00 00  |xxxxxxx.........|
0000c0f0  00 00 00 00 00 00 00 00  00 00 00 00 00 00 00 00  |................|
0000c100  00 00 00 00 00 00 00 00  00 00 00 00 00 00 00 00  |................|
0000c110  00 00 00 00 00 00 00 00  00 00 00 00 00 00 00 00  |................|
發現hhhhhhhh一行是在的,于是做個 analyze,查看是否會被清除。
 
mysql> optimize table  test;
+--------------+----------+----------+-------------------------------------------------------------------+
| Table        | Op       | Msg_type | Msg_text                                                          |
+--------------+----------+----------+-------------------------------------------------------------------+
| cwdtest.test | optimize | note     | Table does not support optimize, doing recreate + analyze instead |
| cwdtest.test | optimize | status   | OK                                                                |
+--------------+----------+----------+-------------------------------------------------------------------+
2 rows in set (0.03 sec)
mysql> analyze table test;
+--------------+---------+----------+----------+
| Table        | Op      | Msg_type | Msg_text |
+--------------+---------+----------+----------+
| cwdtest.test | analyze | status   | OK       |
+--------------+---------+----------+----------+
再查hexdump
 
0000c000  f0 d3 26 ea 00 00 00 03  ff ff ff ff ff ff ff ff  |..&.............|
0000c010  00 00 00 00 00 29 7b ce  45 bf 00 00 00 00 00 00  |.....){.E.......|
0000c020  00 00 00 00 00 24 00 02  00 bc 80 04 00 00 00 00  |.....$..........|
0000c030  00 a2 00 02 00 00 00 02  00 00 00 00 00 00 00 00  |................|
0000c040  00 00 00 00 00 00 00 00  00 36 00 00 00 24 00 00  |.........6...$..|
0000c050  00 02 00 f2 00 00 00 24  00 00 00 02 00 32 01 00  |.......$.....2..|
0000c060  02 00 1d 69 6e 66 69 6d  75 6d 00 03 00 0b 00 00  |...infimum......|
0000c070  73 75 70 72 65 6d 75 6d  08 00 00 00 00 10 00 22  |supremum......."|
0000c080  00 00 00 00 02 0d 00 00  00 00 0b 36 ab 00 00 01  |...........6....|
0000c090  22 01 10 61 61 61 61 61  61 61 61 07 01 00 00 18  |"..aaaaaaaa.....|
0000c0a0  ff ce 00 00 00 00 02 0e  00 00 00 00 0b 37 ac 00  |.............7..|
0000c0b0  00 01 23 01 10 63 63 63  63 63 63 63 00 00 00 00  |..#..ccccccc....|
0000c0c0  00 00 00 00 00 00 00 00  00 00 00 00 00 00 00 00  |................|
0000c0d0  00 00 00 00 00 00 00 00  00 00 00 00 00 00 00 00  |................|
0000c0e0  00 00 00 00 00 00 00 00  00 00 00 00 00 00 00 00  |................|
0000c0f0  00 00 00 00 00 00 00 00  00 00 00 00 00 00 00 00  |................|
0000c100  00 00 00 00 00 00 00 00  00 00 00 00 00 00 00 00  |................|
此時已被清理掉了。所以,一旦發送誤刪操作且沒有備份,第一時間應該趕緊把ibd文件備份。

(編輯:武林網)

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久国产精品久久久久久| 欧美日韩高清在线观看| 91视频88av| 日韩精品中文字幕在线播放| 日韩在线欧美在线国产在线| 欧美视频裸体精品| 亚洲欧美日韩国产中文专区| 国产91精品久久久久久| 日本道色综合久久影院| 久久国产精品免费视频| 久久天天躁狠狠躁夜夜爽蜜月| 国产精品成人免费电影| 亚洲精品久久久久久久久久久久久| 国产美女直播视频一区| 日韩在线视频免费观看| 日本国产欧美一区二区三区| 日韩日本欧美亚洲| 欧美激情伊人电影| 日韩精品在线影院| 国产999精品久久久影片官网| 欧美xxxx做受欧美.88| 91av在线国产| 欧美成人高清视频| 成人h猎奇视频网站| 国产精品v片在线观看不卡| 欧美电影免费播放| 青青草99啪国产免费| 日韩中文在线中文网在线观看| 777国产偷窥盗摄精品视频| 日本午夜精品理论片a级appf发布| 2019亚洲男人天堂| 亚洲影视中文字幕| 亚洲国产成人久久综合| 欧美中文字幕在线视频| 亚洲性av在线| 日韩av手机在线| 中日韩午夜理伦电影免费| 欧美一级淫片videoshd| 亚洲午夜国产成人av电影男同| 91中文在线视频| 国产精品老女人精品视频| 91黑丝在线观看| 国产成人激情小视频| 91免费精品国偷自产在线| 97色在线播放视频| 国产亚洲综合久久| 欧美精品18videos性欧美| 国产精品久久不能| 日本韩国欧美精品大片卡二| 九九视频直播综合网| 91久久久久久久久久久| 亚洲欧美在线第一页| 亚洲国产精品网站| 亚洲人成网7777777国产| 伦伦影院午夜日韩欧美限制| 成人黄色av播放免费| 欲色天天网综合久久| 亚洲激情小视频| 狠狠综合久久av一区二区小说| 国产欧美va欧美va香蕉在| 成人黄色短视频在线观看| 最近2019好看的中文字幕免费| 国产精品www网站| 高清亚洲成在人网站天堂| 91香蕉嫩草影院入口| 亚洲欧美在线播放| 久久综合伊人77777尤物| 久久久久久伊人| 欧美猛少妇色xxxxx| 亚洲第一色中文字幕| 国产日韩精品在线播放| 国产精品久久久久久久久免费看| 久久青草精品视频免费观看| 成人精品视频在线| 成人美女av在线直播| 欧美久久精品一级黑人c片| 亚洲va电影大全| 欧美性视频精品| 国产精品69av| 亚洲欧洲在线观看| 中文字幕亚洲二区| 色妞色视频一区二区三区四区| 欧美日韩国产激情| 亚洲精品有码在线| 日韩精品视频免费在线观看| 亚洲精品视频在线播放| 色偷偷噜噜噜亚洲男人| 亚洲图片欧洲图片av| 成人免费xxxxx在线观看| 色在人av网站天堂精品| 亚洲成人三级在线| 中国china体内裑精亚洲片| 91老司机精品视频| 国产精品综合网站| 91精品久久久久久久久青青| 亚洲国产精品网站| 欧美黄色三级网站| 亚洲福利在线播放| 26uuu日韩精品一区二区| 伊人久久男人天堂| 在线观看欧美视频| 欧美老少做受xxxx高潮| 国产精品久久久久久亚洲影视| 国产精品麻豆va在线播放| 亚洲欧美日韩在线一区| 久久精品视频在线观看| 97久久久免费福利网址| 亚洲国产精品美女| 日韩视频在线免费观看| 日韩av在线看| 亚洲的天堂在线中文字幕| 国产精品偷伦一区二区| 亚洲国产精品久久久久秋霞不卡| 亚洲aⅴ男人的天堂在线观看| 在线观看国产精品日韩av| 色噜噜狠狠狠综合曰曰曰88av| 亚洲精品国产拍免费91在线| 国产视频精品一区二区三区| 九九久久久久99精品| 日韩美女免费视频| 欧亚精品在线观看| 亚洲香蕉成人av网站在线观看| 欧美精品做受xxx性少妇| 精品国产31久久久久久| 91中文字幕在线| 亚洲一级片在线看| 538国产精品一区二区免费视频| 色yeye香蕉凹凸一区二区av| 91精品在线影院| 国产精品美女主播在线观看纯欲| 亚洲美女激情视频| 国产精品私拍pans大尺度在线| 中文精品99久久国产香蕉| 欧美专区在线观看| 日韩中文字幕免费看| 日韩av在线网站| 国产午夜精品视频免费不卡69堂| 国产精品视频午夜| 精品福利在线视频| 日韩欧美国产骚| 国产精品99一区| 成人有码在线播放| 亚洲一区二区中文| 国产啪精品视频网站| 欧美激情精品久久久久久变态| 亚洲最新av在线网站| 国产不卡av在线| 日韩最新中文字幕电影免费看| 午夜精品久久久久久久久久久久久| 欧美激情精品久久久久| 91免费综合在线| 精品视频在线导航| 成人免费福利在线| yellow中文字幕久久| 岛国av一区二区三区| 77777少妇光屁股久久一区| 日韩av成人在线观看| 久久精品国产亚洲精品| 国产欧美一区二区三区久久| 91视频88av| 久久久久久久久久久成人| 亚洲国产精品资源| 国产精品久久久久久久9999| 成人观看高清在线观看免费|