mysql_ping 无回复_MySQL异常恢复之无主键情况下innodb数据恢复的方法

本文详细介绍了在MySQL的InnoDB引擎中,如何在没有主键的情况下进行数据恢复。通过创建模拟表、解析innodb文件、恢复数据字典及分析数据,最终成功恢复了数据,尽管可能存在少量重复记录。此过程对数据库异常恢复提供了参考。
摘要由CSDN通过智能技术生成

本文讲述了MySQL异常恢复之无主键情况下innodb数据恢复的方法。分享给大家供大家参考,具体如下:

在mysql的innodb引擎的数据库异常恢复中,一般都要求有主键或者唯一index,其实这个不是必须的,当没有index信息之时,可以在整个表级别的index_id进行恢复

创建模拟表—无主键

mysql> CREATE TABLE `t1` (

-> `messageId` varchar(30) character set utf8 NOT NULL,

-> `tokenId` varchar(20) character set utf8 NOT NULL,

-> `mobile` varchar(14) character set utf8 default NULL,

-> `msgFormat` int(1) NOT NULL,

-> `msgContent` varchar(1000) character set utf8 default NULL,

-> `scheduleDate` timestamp NOT NULL default '0000-00-00 00:00:00',

-> `deliverState` int(1) default NULL,

-> `deliverdTime` timestamp NOT NULL default '0000-00-00 00:00:00'

-> ) ENGINE=INnodb DEFAULT CHARSET=utf8;

Query OK, 0 rows affected (0.00 sec)

mysql> insert into t1 select * from sms_service.sms_send_record;

Query OK, 11 rows affected (0.00 sec)

Records: 11 Duplicates: 0 Warnings: 0

…………

mysql> insert into t1 select * from t1;

Query OK, 81664 rows affected (2.86 sec)

Records: 81664 Duplicates: 0 Warnings: 0

mysql> insert into t1 select * from t1;

Query OK, 163328 rows affected (2.74 sec)

Records: 163328 Duplicates: 0 Warnings: 0

mysql> select count(*) from t1;

+----------+

| count(*) |

+----------+

| 326656 |

+----------+

1 row in set (0.15 sec)

解析innodb文件

[root@web103 mysql_recovery]# rm -rf pages-ibdata1/

[root@web103 mysql_recovery]# ./stream_parser -f /var/lib/mysql/ibdata1

Opening file: /var/lib/mysql/ibdata1

File information:

ID of device containing file: 2049

inode number: 1344553

protection: 100660 (regular file)

number of hard links: 1

user ID of owner: 27

group ID of owner: 27

device ID (if special file): 0

blocksize for filesystem I/O: 4096

number of blocks allocated: 463312

time of last access: 1440819443 Sat Aug 29 11:37:23 2015

time of last modification: 1440819463 Sat Aug 29 11:37:43 2015

time of last status change: 1440819463 Sat Aug 29 11:37:43 2015

total size, in bytes: 236978176 (226.000 MiB)

Size to process: 236978176 (226.000 MiB)

Opening file: /var/lib/mysql/ibdata1

File information:

ID of device containing file: 2049

inode number: 1344553

protection: 100660 (regular file)

number of hard links: 1

user ID of owner: 27

group ID of owner: 27

device ID (if special file): 0

blocksize for filesystem I/O: 4096

number of blocks allocated: 463312

Opening file: /var/lib/mysql/ibdata1

File information:

time of last access: 1440819443 Sat Aug 29 11:37:23 2015

time of last modification: 1440819463 Sat Aug 29 11:37:43 2015

ID of device containing file: 2049

inode number: 1344553

protection: 100660 time of last status change: 1440819463 Sat Aug 29 11:37:43 2015

total size, in bytes: 236978176 (226.000 MiB)

Size to process: 236978176 (226.000 MiB)

Opening file: /var/lib/mysql/ibdata1

File information:

ID of device containing file: 2049

inode number: 1344553

protection: 100660 (regular file)

number of hard links: 1

user ID of owner: 27

group ID of owner: 27

device ID (if special file): 0

blocksize for filesystem I/O: 4096

number of blocks allocated: 463312

time of last access: 1440819443 Sat Aug 29 11:37:23 2015

time of last modification: 1440819463 Sat Aug 29 11:37:43 2015

time of last status change: 1440819463 Sat Aug 29 11:37:43 2015

total size, in bytes: 236978176 (226.000 MiB)

Size to process: 236978176 (226.000 MiB)

(regular file)

number of hard links: 1

user ID of owner: 27

group ID of owner: 27

device ID (if special file): 0

blocksize for filesystem I/O: 4096

number of blocks allocated: 463312

time of last access: 1440819443 Sat Aug 29 11:37:23 2015

time of last modification: 1440819463 Sat Aug 29 11:37:43 2015

time of last status change: 1440819463 Sat Aug 29 11:37:43 2015

total size, in bytes: 236978176 (226.000 MiB)

Size to process: 236978176 (226.000 MiB)

Opening file: /var/lib/mysql/ibdata1

File information:

ID of device containing file: 2049

inode number: 1344553

protection: 100660 (regular file)

number of hard links: 1

user ID of owner: 27

group ID of owner: 27

device ID (if special file): 0

blocksize for filesystem I/O: 4096

number of blocks allocated: 463312

time of last access: 1440819443 Sat Aug 29 11:37:23 2015

time of last modification: 1440819463 Sat Aug 29 11:37:43 2015

time of last status change: 1440819463 Sat Aug 29 11:37:43 2015

total size, in bytes: 236978176 (226.000 MiB)

Size to process: 236978176 (226.000 MiB)

Opening file: /var/lib/mysql/ibdata1

File information:

ID of device containing file: 2049

inode number: 1344553

protection: 100660 (regular file)

number of hard links: 1

user ID of owner: 27

group ID of owner: 27

device ID (if special file): 0

blocksize for filesystem I/O: 4096

number of blocks allocated: 463312

time of last access: 1440819443 Sat Aug 29 11:37:23 2015

time of last modification: 1440819463 Sat Aug 29 11:37:43 2015

time of last status change: 1440819463 Sat Aug 29 11:37:43 2015

Opening file: /var/lib/mysql/ibdata1

File information:

ID of device containing file: 2049

inode number: 1344553

protection: 100660 (regular file)

number of hard links: 1

user ID of owner: 27

group ID of owner: 27

device ID (if special file): 0

blocksize for filesystem I/O: 4096

number of blocks allocated: 463312

total size, in bytes: 236978176 (226.000 MiB)

Size to process: 236978176 (226.000 MiB)

time of last access: 1440819443 Sat Aug 29 11:37:23 2015

time of last modification: 1440819463 Sat Aug 29 11:37:43 2015

time of last status change: 1440819463 Sat Aug 29 11:37:43 2015

total size, in bytes: 236978176 (226.000 MiB)

Size to process: 236978176 (226.000 MiB)

Opening file: /var/lib/mysql/ibdata1

File information:

ID of device containing file: 2049

inode number: 1344553

protection: 100660 (regular file)

number of hard links: 1

user ID of owner: 27

group ID of owner: 27

device ID (if special file): 0

blocksize for filesystem I/O: 4096

number of blocks allocated: 463312

time of last access: 1440819465 Sat Aug 29 11:37:45 2015

time of last modification: 1440819463 Sat Aug 29 11:37:43 2015

time of last status change: 1440819463 Sat Aug 29 11:37:43 2015

total size, in bytes: 236978176 (226.000 MiB)

Size to process: 236978176 (226.000 MiB)

All workers finished in 0 sec

恢复数据字典

[root@web103 mysql_recovery]# ./recover_dictionary.sh

Generating dictionary tables dumps... OK

Creating test database ... OK

Creating dictionary tables in database test:

SYS_TABLES ... OK

SYS_COLUMNS ... OK

SYS_INDEXES ... OK

SYS_FIELDS ... OK

All OK

Loading dictionary tables data:

SYS_TABLES ... 48 recs OK

SYS_COLUMNS ... 397 recs OK

SYS_INDEXES ... 67 recs OK

SYS_FIELDS ... 89 recs OK

All OK

分析数据字典,找出来index_id

这里需要注意对于没有主键的表恢复,我们对应的类型是GEN_CLUST_INDEX

mysql> select * from SYS_TABLES where name='test/t1';

+----------------------------------------+-----+-------------+------+--------+---------+--------------+-------+

| NAME | ID | N_COLS | TYPE | MIX_ID | MIX_LEN | CLUSTER_NAME | SPACE |

+----------------------------------------+-----+-------------+------+--------+---------+--------------+-------+

| test/t1 | 100 | 8 | 1 | 0 | 0 | | 0 |

+----------------------------------------+-----+-------------+------+--------+---------+--------------+-------+

40 rows in set (0.00 sec)

mysql> SELECT * FROM SYS_INDEXES where table_id=100;

+----------+-----+------------------------------+----------+------+-------+------------+

| TABLE_ID | ID | NAME | N_FIELDS | TYPE | SPACE | PAGE_NO |

+----------+-----+------------------------------+----------+------+-------+------------+

| 100 | 119 | GEN_CLUST_INDEX | 0 | 1 | 0 | 2951 |

+----------+-----+------------------------------+----------+------+-------+------------+

67 rows in set (0.00 sec)

恢复数据

root@web103 mysql_recovery]# ./c_parser -5f pages-ibdata1/FIL_PAGE_INDEX/0000000000000119.page -t dictionary/t1.sql >/tmp/2.txt 2>2.sql

[root@web103 mysql_recovery]# more /tmp/2.txt

-- Page id: 10848, Format: COMPACT, Records list: Valid, Expected records: (73 73)

00000002141B 0000009924F2 80000027133548 t1 "82334502212106951" "SDK-BBX-010-18681" "13718311436" 8 "尊敬的用户您好:您的手机验证码为916515如非本人操作,请拨打奥

斯卡客服:400-620-7575。" "2010-01-01 00:00:00" 0 "1970-01-01 07:00:00"

00000002141C 0000009924F2 80000027133558 t1 "82339012756833423" "SDK-BBX-010-18681" "13718311436" 8 "尊敬的用户您好:您的手机验证码为396108如非本人操作,请拨打奥

斯卡客服:400-620-7575。" "2010-01-01 00:00:00" 0 "1970-01-01 07:00:00"

00000002141D 0000009924F2 80000027133568 t1 "8234322198577796" "SDK-BBX-010-18681" "13718311436" 8 "尊敬的用户您好:您的手机验证码为935297如非本人操作,请拨打奥

斯卡客服:400-620-7575。" "2010-01-01 00:00:00" 0 "1970-01-01 07:00:00"

00000002141E 0000009924F2 80000027133578 t1 "10235259536125650" "SDK-BBX-010-18681" "13718311436" 8 "尊敬的用户您好:您的手机验证码为474851如非本人操作,请拨打奥

斯卡客服:400-620-7575。" "2010-01-01 00:00:00" 0 "1970-01-01 07:00:00"

00000002141F 0000009924F2 80000027133588 t1 "10235353811295807" "SDK-BBX-010-18681" "13718311436" 8 "尊敬的用户您好:您的手机验证码为444632如非本人操作,请拨打奥

斯卡客服:400-620-7575。" "2010-01-01 00:00:00" 0 "1970-01-01 07:00:00"

000000021420 0000009924F2 80000027133598 t1 "102354211240398235" "SDK-BBX-010-18681" "13718311436" 8 "尊敬的用户您好:您的手机验证码为478503如非本人操作,请拨打奥

斯卡客服:400-620-7575。" "2010-01-01 00:00:00" 0 "1970-01-01 07:00:00"

000000021421 0000009924F2 800000271335A8 t1 "102354554052884567" "SDK-BBX-010-18681" "13718311436" 8 "尊敬的用户您好:您的手机验证码为216825如非本人操作,请拨打奥

斯卡客服:400-620-7575。" "2010-01-01 00:00:00" 0 "1970-01-01 07:00:00"

000000021422 0000009924F2 800000271335B8 t1 "132213454294519126" "SDK-BBX-010-18681" "13718311436" 8 "尊敬的用户您好:您的手机验证码为854812如非本人操作,请拨打奥

斯卡客服:400-620-7575。" "2010-01-01 00:00:00" 0 "1970-01-01 07:00:00"

000000021423 0000009924F2 800000271335C8 t1 "82329022242584577" "SDK-BBX-010-18681" "13718311436" 8 "尊敬的用户您好:您的手机验证码为253127如非本人操作,请拨打奥

斯卡客服:400-620-7575。" "2010-01-01 00:00:00" 0 "2015-08-26 22:02:17"

…………

[root@web103 mysql_recovery]# cat /tmp/2.txt|grep -v "Page id:"|wc -l

380731

因为没有主键,使得恢复出来记录可能有一些重复,整体而言,可以较为完美的恢复数据

希望本文所述对大家MySQL数据库计有所帮助。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值