您的位置:首页 > 其它

Innodb ibdata数据文件误删,如何恢复

2016-02-25 11:39 447 查看
Innodb的ibdata数据文件误删除后的操作流程:
注意:误删除后,你的数据库是还可以工作的,数据照样可以写入,切记,千万不要把mysqld进程杀死,否则就没法挽救了。

首先找到mysqld的进程pid,如pid是 1111
ll /proc/1111/fd |egrep 'ib_|ibdata'
10 -> /opt/mysql/data/ib_logfile111 -> /opt/mysql/data/ib_logfile2
12 -> /opt/mysql/data/ibdata1
13 -> /opt/mysql/data/ib_logfile0
12就是你要找的文件。

这时可以关掉前端服务,或者执行:flush tables with read lock;是为了停止继续写入,便于后边的恢复操作。

让脏页尽快刷入到磁盘里。set global innodb_max_diryt_pages_pct=0;时刻查看binlog日志写入情况。show master status;也可以进行一些show engine innodb status\G 对一些脏页的查看。

以上工作都处理好后,就可以进行恢复操作了。cp 12 /opt/mysql/data/ibdata1,然后修改相应的权限。重启mysql即可。

不要在生产环境下进行测试哦。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息