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即可。
不要在生产环境下进行测试哦。
注意:误删除后,你的数据库是还可以工作的,数据照样可以写入,切记,千万不要把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即可。
不要在生产环境下进行测试哦。
相关文章推荐
- Oracle表空间数据文件移动的方法
- php读取二进制流(C语言结构体struct数据文件)的深入解析
- oracle 表空间
- oracle数据文件datafile找不到
- 统计软件第六次作业
- Oracle数据库操作大全(十二)——管理表空间和数据文件
- 添加、删除数据文件个数
- Android - 访问手机操作系统
- 创建表空间、用户、扩容、移动数据文件
- 新建数据文件的初始大小
- Oracle 数据库/表空间/数据文件之间的关系
- 针对Excel表格文件操作的编程实现
- Oracle数据文件
- Oracle单个数据文件超过32G后扩容
- oracle增加表空间数据文件大小
- mongodb删除数据后无法释放空间
- outlook显示无法打开文件夹集合
- 表空间和数据文件的管理
- 公司招聘软件研发程序员的一道考题--MS SQL Server数据库数据文件页面头部结构
- 管理表空间和数据文件