Innodb ibdata数据文件误删,如何恢复
Innodb的ibdata數(shù)據(jù)文件誤刪除后的操作流程:
注意:誤刪除后,你的數(shù)據(jù)庫是還可以工作的,數(shù)據(jù)照樣可以寫入,切記,千萬不要把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就是你要找的文件。
這時可以關(guān)掉前端服務(wù),或者執(zhí)行:flush tables with read lock;是為了停止繼續(xù)寫入,便于后邊的恢復(fù)操作。
讓臟頁盡快刷入到磁盤里。set global innodb_max_diryt_pages_pct=0;時刻查看binlog日志寫入情況。show master status;也可以進行一些show engine innodb status\G 對一些臟頁的查看。
以上工作都處理好后,就可以進行恢復(fù)操作了。cp 12 /opt/mysql/data/ibdata1,然后修改相應(yīng)的權(quán)限。重啟mysql即可。
不要在生產(chǎn)環(huán)境下進行測試哦。
轉(zhuǎn)載于:https://blog.51cto.com/7078981/1744921
總結(jié)
以上是生活随笔為你收集整理的Innodb ibdata数据文件误删,如何恢复的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 为Elasticsearch添加中文分词
- 下一篇: 明日之后服务器维修会补偿什么,明日之后: