Innodb的ibdata数据文件误删除后的操作流程:

  • 注意:误删除后,你的数据库是还可以工作的,数据照样可以写入,切记,千万不要把mysqld进程杀死,否则就没法挽救了。

  1. 首先找到mysqld的进程pid,如pid是 1111

    ll /proc/1111/fd |egrep 'ib_|ibdata'

    10 -> /opt/mysql/data/ib_logfile1

    11 -> /opt/mysql/data/ib_logfile2

    12 -> /opt/mysql/data/ibdata1

    13 -> /opt/mysql/data/ib_logfile0

    12就是你要找的文件。

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

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

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


不要在生产环境下进行测试哦。