mysql數(shù)據(jù)如何通過data文件恢復(fù)
mysql數(shù)據(jù)通過data文件恢復(fù)
mysql磁盤文件被損壞,無法啟動(dòng),能看到data文件,在沒有備份的話如何復(fù)原?
情景1:知道數(shù)據(jù)庫中的表結(jié)構(gòu)
1、先執(zhí)行表結(jié)構(gòu)語句
2、解除綁定
alter table `表1` ?discard ?tablespace; alter table `表2` ?discard ?tablespace; ......
此時(shí)當(dāng)前數(shù)據(jù)庫下所有的.idb文件都會(huì)被刪除,也就是只剩下表結(jié)構(gòu),原表數(shù)據(jù)被刪除
3、導(dǎo)入 .idb文件現(xiàn)有數(shù)據(jù)庫
也就是添加表數(shù)據(jù),不過,目前還沒有綁定
alter table `表1` ?import ? tablespace; alter table `表2` ?import ? tablespace; ......
mysql數(shù)據(jù)恢復(fù)方法個(gè)人總結(jié)
mysql具有binlog功能,可以記錄對(duì)表進(jìn)行過的操作、執(zhí)行過的sql語句;
以下主要是總結(jié)下binlog的開啟方法、使用方法等;
如果誤刪數(shù)據(jù)庫表中的某些數(shù)據(jù)、或者誤刪整個(gè)表、誤修改表結(jié)構(gòu)等,就可以使用這個(gè)方法進(jìn)行恢復(fù)。
步驟
1.如果想使用MySql數(shù)據(jù)恢復(fù)功能,首先需要修改Mysql配置文件,開啟binlog功能。(有些版本binlog默認(rèn)是不開啟的,因此需要手動(dòng)修改配置文件開啟)
(1)windows環(huán)境
配置文件名稱為my.ini,可以安裝軟件everything搜索這個(gè)文件。路徑樣例如下:
C:ProgramDataMySQLMySQL Server 5.7my.ini
(2)linux環(huán)境
配置文件名稱為my.cnf,可以使用find命令搜索文件所在位置:
sudo find / -name my.cnf
位置樣例如下:
/etc/my.cnf
2.找到配置文件后(my.ini/my.cnf),新增以下配置即可(當(dāng)然先看看配置文件是否已配置了這行,不要重復(fù)了):
log-bin=mysqlbinlog binlog-format=ROW
或者也可以指定binlog的位置(下方是linux下的路徑):
log-bin=/data/mysql/log/mysqlbinlog binlog-format=ROW
注意,指定binlog在某個(gè)文件夾下時(shí),必須自己創(chuàng)建文件夾,否則重啟mysql會(huì)報(bào)錯(cuò)。
3.配置完成后,重啟mysql。
4.現(xiàn)在,對(duì)mysql的數(shù)據(jù)庫、表、數(shù)據(jù)等操作、執(zhí)行增刪改sql,都會(huì)記錄到binlog中。(搜索mysqlbinlog就可以找到這個(gè)日志文件)
5.進(jìn)行測(cè)試,新建一個(gè)表binlog_test,列隨意,然后寫幾行數(shù)據(jù),然后清空表數(shù)據(jù)。(準(zhǔn)備使用binlog還原數(shù)據(jù))
6.查看binlog的命令如下:
mysql> show binlog events; ? #只查看第一個(gè)binlog文件的內(nèi)容 mysql> show binlog events in 'mysqlbinlog.000002';#查看指定binlog文件的內(nèi)容 mysql> show binary logs; ?#獲取binlog文件列表 mysql> show master status; #查看當(dāng)前正在寫入的binlog文件
7.首先看當(dāng)前使用的是哪個(gè)binlog:
show master status;
本人執(zhí)行后,發(fā)現(xiàn)當(dāng)前使用的binlog是:mysqlbinlog.000004
8.然后查看這個(gè)binlog的內(nèi)容:
show binlog events in 'mysqlbinlog.000004';
執(zhí)行后,可以從查詢結(jié)果的Info列中,找到剛才創(chuàng)建binlog_test表的sql(對(duì)應(yīng)的Event_type是Query);
可以看到剛才清空表數(shù)據(jù)的記錄行,Event_type是Delete_rows;
在上一些,可以看到創(chuàng)建表后、新增數(shù)據(jù)的Event_type是Write_rows;
9.分析這個(gè)binlog,我們的目標(biāo)是還原剛才被刪除的數(shù)據(jù),因此找到create table語句后的第一個(gè)Event_type是Query的行,它的Pos為460;
再找到Event_type是Delete_rows上面最接近的、Info中是COMMIT的行,它的Event_type是Xid,End_log_pos是1199。
(每一行的End_log_pos對(duì)應(yīng)下一行的Pos)
10.現(xiàn)在找到了一個(gè)范圍,從460到1199之間的執(zhí)行日志,就是給表binlog_test增加數(shù)據(jù)的日志,因此只要重復(fù)執(zhí)行這之間的操作,就可以還原數(shù)據(jù)了。
11-1.windows下,找到mysqlbinlog.exe的位置;
linux下,找到mysqlbinlog的位置(這個(gè)是mysql的bin目錄下的一個(gè)可執(zhí)行文件);
然后執(zhí)行以下命令,即可還原數(shù)據(jù):
mysqlbinlog --no-defaults --start-position=460 --stop-position=1199 "C:ProgramDataMySQLMySQL Sever 5.7Datamysqlbinlog.000004" -d test | mysql -uroot -proot test
其中,指定了開始位置為460,結(jié)束位置為1199,命令執(zhí)行后就會(huì)讀取日志中指定范圍內(nèi)的命令并重新執(zhí)行。
其它命令的含義為:
- "
-d test
"的意思是,指定數(shù)據(jù)庫為test(binlog_test表在test數(shù)據(jù)庫中) - "
|
"是管道符 - "
mysql -uroot -proot test
"是mysql的賬號(hào)密碼、登陸目標(biāo)數(shù)據(jù)庫 - "
-uroot
":賬號(hào)是root - "
-proot
":密碼是root - "
test
":數(shù)據(jù)庫是test
11-2.也可以把binlog日志中,指定范圍內(nèi)的日志導(dǎo)出,然后自己執(zhí)行source命令還原數(shù)據(jù),如下:
mysqlbinlog "C:ProgramDataMySQLMySQL Sever 5.7Datamysqlbinlog.000004" -d test --skip-gtids --start-position=460 --stop-position=1199 > test.sql
執(zhí)行這個(gè)命令后,指定范圍內(nèi)的日志被導(dǎo)出到test.sql中;
然后登陸mysql,執(zhí)行命令:
mysql> use test;? mysql> source test.sql;
這樣就可以還原數(shù)據(jù)了。
其它筆記
1.如果使用truncate刪除表的數(shù)據(jù),binlog中也會(huì)新增幾行記錄,記錄truncate操作,樣例如下:
mysqlbinlog.000004 | 3122 | Query | 1 | 3211 | use 'test'; TRUNCATE 'binlog_test'
如果想恢復(fù)數(shù)據(jù),就需要找到最開始插入數(shù)據(jù)的Pos、到truncate之前的End_log_pos,然后重新執(zhí)行這期間的命令。
2.增刪改操作會(huì)記錄到binlog中,慢查詢sql也可以記錄到慢查詢log中,不過也需要自己修改配置文件開啟慢查詢?nèi)罩尽?/p>
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Mysql中substring_index函數(shù)實(shí)現(xiàn)字符分割一行變多行
在MySQL中,字符串分割是一個(gè)常見的操作,本文主要介紹了Mysql中substring_index函數(shù)實(shí)現(xiàn)字符分割一行變多行,具有一定的參考價(jià)值,感興趣的可以了解一下2023-12-12一文教你學(xué)會(huì)定位線上MySQL鎖超時(shí)問題
這篇文章主要介紹了一文教你學(xué)會(huì)定位線上MySQL鎖超時(shí)問題,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-08-08mysql 修改密碼和設(shè)置允許遠(yuǎn)程登錄
這篇文章主要介紹了mysql 修改密碼和設(shè)置允許遠(yuǎn)程登錄的相關(guān)資料,需要的朋友可以參考下2015-07-07數(shù)據(jù)庫報(bào)錯(cuò):Unknown column 'xxx' in
但凡寫過sql語句的人估計(jì)都曾經(jīng)碰到過類似于Unknown column ‘xxx’ in ‘where clause’的問題,這篇文章主要給大家介紹了關(guān)于數(shù)據(jù)庫報(bào)錯(cuò):Unknown column 'xxx' in 'where clause'問題的解決過程,需要的朋友可以參考下2023-03-03mssql2008 自定義表類型實(shí)現(xiàn)(批量插入或者修改)
在做大型網(wǎng)站或者系統(tǒng)的時(shí)候,經(jīng)常會(huì)遇到個(gè)問題就是批量插入或者修改數(shù)據(jù)庫;今天這邊不講SqlBulkCopy,只簡(jiǎn)單講sql自定義表類型,感興趣的朋友可以了解下哦,希望本文對(duì)你有所幫助2013-01-01