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即可。
不要在生产环境下进行测试哦。