MySQL數(shù)據(jù)庫(kù)表修復(fù) MyISAM
一:MySQL中MyISAM表?yè)p壞原因總結(jié):
1、 服務(wù)器突然斷電導(dǎo)致數(shù)據(jù)文件損壞;強(qiáng)制關(guān)機(jī),沒(méi)有先關(guān)閉mysql 服務(wù);mysqld 進(jìn)程在寫表時(shí)被殺掉。
2、 磁盤損壞。
3、 服務(wù)器死機(jī)。
4、 mysql 本身的bug 。
二:MySQL中MyISAM表?yè)p壞的癥狀總結(jié):
1 、查詢數(shù)據(jù)時(shí)報(bào)出錯(cuò)誤:Incorrect key file for table: '...'. Try to repair it
2 、查詢不能在表中找到行或返回不完全的數(shù)據(jù)。
3 、Error: Table '...' is marked as crashed and should be repaired 。
4 、打開表失敗: Can't open file: ‘×××.MYI' (errno: 145) 。
三:MySQL中MyISAM表?yè)p壞的預(yù)防:
1 、定期檢查MyISAM 表??梢允褂胢yisamchk,也可以使用mysqlcheck,還可以使用check table。
2 、在做過(guò)大量的更新或刪除操作后,使用mysqlcheck或者optimize table來(lái)優(yōu)化表,這樣既減少了文件碎片,又減少了表?yè)p壞的概率。 3 、關(guān)閉服務(wù)器前,先關(guān)閉mysqld (正常關(guān)閉服務(wù),不要使用kill -9 來(lái)殺進(jìn)程)。
4 、使用ups 電源,避免出現(xiàn)突然斷電的情況。
5 、使用最新的穩(wěn)定發(fā)布版mysql ,減少mysql 本身的bug 導(dǎo)致表?yè)p壞。
6 、對(duì)磁盤做raid ,減少磁盤出錯(cuò)并提高性能。
7 、數(shù)據(jù)庫(kù)服務(wù)器最好只跑mysqld 和必要的其他服務(wù),不要跑其他業(yè)務(wù)服務(wù),這樣減少死機(jī)導(dǎo)致表?yè)p壞的可能。
四:MySQL中MyISAM表?yè)p壞的修復(fù)總結(jié):
1 、如果mysqld已經(jīng)宕掉,且無(wú)法啟動(dòng),那么可以通過(guò)mysiamchk工具來(lái)進(jìn)行修復(fù)。此工具在mysqld服務(wù)沒(méi)有啟動(dòng)時(shí)才可以使用。該工具可以檢查并分析修復(fù)MyISAM表。
2 、如果mysqld仍在運(yùn)行,或者可以重新啟動(dòng),那么可以通過(guò)mysqlcheck工具來(lái)進(jìn)行修復(fù)?;蛘咧苯油ㄟ^(guò)mysql的內(nèi)置修復(fù)SQL語(yǔ)句來(lái)修復(fù):CHECK TABLE,REPAIR TABLE ,ANALYSE TABLE,OPTIMIZE TABLE。這兩種方法可以同樣達(dá)到對(duì)表的修復(fù)作用。 以上兩種方式各有應(yīng)用場(chǎng)景。
MySQL數(shù)據(jù)表?yè)p壞的巧妙修復(fù) 修復(fù)mysql表之前首先要知道是哪個(gè)表出了問(wèn)題
可以用root登錄后在information_schema里查找有問(wèn)題的表名
select TABLE_SCHEMA as DB_DBNAME,TABLE_NAME from INFORMATION_SCHEMA.tables where engine is null;
可以通過(guò)事件查看器里是否有
應(yīng)用程序日志--類型為"錯(cuò)誤"--事件來(lái)源為"Mysql"的錯(cuò)誤日志,大概內(nèi)容為
1 xxxxx: Table '.xxxx' is marked as crashed and should be repaired
或者直接在phpmyadmin中查看有哪些表出了問(wèn)題比如顯示“使用中”
如果查到問(wèn)題表后,可以使用一下命令來(lái)修復(fù)mysql數(shù)據(jù)庫(kù)中的MYISAM表
1、check, repair
例如abc的test表有問(wèn)題
# mysql -u root -p 'abc'; //登錄mysql控制臺(tái),并進(jìn)入abc數(shù)據(jù)庫(kù)
mysql> check table test; //如果有問(wèn)題Msg_type里會(huì)有warning或error。沒(méi)有問(wèn)題的話出現(xiàn)的結(jié)果Status是OK
mysql> repair table test; // 修復(fù)test表(多個(gè)表名用“逗號(hào)”隔開)
mysql> check table test; // 再次檢查確認(rèn)是否修復(fù)成功
2. myisamchk, isamchk
其中myisamchk適用于MYISAM類型的數(shù)據(jù)表,而isamchk適用于ISAM類型的MySQL數(shù)據(jù)表。這兩條命令的主要參數(shù)相同,一般新的系統(tǒng)都使用MYISAM作為缺省的數(shù)據(jù)表類型,這里以myisamchk為例子進(jìn)行說(shuō)明。當(dāng)發(fā)現(xiàn)某個(gè)數(shù)據(jù)表出現(xiàn)問(wèn)題時(shí)可以使用:
myisamchk tablename.MYI
進(jìn)行檢測(cè),如果需要修復(fù)的話,可以使用:
myisamchk -of tablename.MYI
關(guān)于myisamchk的詳細(xì)參數(shù)說(shuō)明,可以參見(jiàn)它的使用幫助。需要注意的時(shí)在進(jìn)行修改時(shí)必須確保MySQL服務(wù)器沒(méi)有訪問(wèn)這個(gè)MySQL數(shù)據(jù)表,保險(xiǎn)的情況下是最好在進(jìn)行檢測(cè)時(shí)把MySQL服務(wù)器Shutdown掉。
mysqladmin -uroot -p shutdown
另外可以把下面的命令放在你的rc.local里面啟動(dòng)MySQL服務(wù)器前:
[ -x /tmp/MySQL.sock ] && /pathtochk/myisamchk -of /DATA_DIR/*/*.MYI
其中的/tmp/MySQL.sock是MySQL監(jiān)聽的Sock文件位置,對(duì)于使用RPM安裝的用戶應(yīng)該是/var/lib/MySQL/MySQL.sock,對(duì)于使用源碼安裝則是/tmp/MySQL.sock可以根據(jù)自己的實(shí)際情況進(jìn)行變更,而pathtochk則是myisamchk所在的位置,DATA_DIR是你的MySQL數(shù)據(jù)庫(kù)存放的位置。
需要注意的時(shí),如果你打算把這條命令放在你的rc.local里面,必須確認(rèn)在執(zhí)行這條指令時(shí)MySQL服務(wù)器必須沒(méi)有啟動(dòng)!
3、檢測(cè)修復(fù)所有數(shù)據(jù)庫(kù)(表)
MySQLcheck -A -o -r -p
mysqlcheck --all-databases -r
- 很全面的Mysql數(shù)據(jù)庫(kù)、數(shù)據(jù)庫(kù)表、數(shù)據(jù)基礎(chǔ)操作筆記(含代碼)
- php+mysqli實(shí)現(xiàn)批量替換數(shù)據(jù)庫(kù)表前綴的方法
- 使用shell檢查并修復(fù)mysql數(shù)據(jù)庫(kù)表的腳本
- 檢查并修復(fù)mysql數(shù)據(jù)庫(kù)表的具體方法
- 用MySQL創(chuàng)建數(shù)據(jù)庫(kù)和數(shù)據(jù)庫(kù)表代碼
- 從MySQL數(shù)據(jù)庫(kù)表中取出隨機(jī)數(shù)據(jù)的代碼
- Mysql數(shù)據(jù)庫(kù)表定期備份的實(shí)現(xiàn)詳解
相關(guān)文章
mysql5.7單實(shí)例自啟動(dòng)服務(wù)配置過(guò)程
這篇文章主要介紹了mysql5.7單實(shí)例自啟動(dòng)服務(wù)配置的過(guò)程,附含配置源碼,有需要的朋友可以借鑒參考下,希望可以有所幫助,感謝閱讀2021-09-09關(guān)于MySQL表中沒(méi)有主鍵時(shí)如何找到重復(fù)的數(shù)據(jù)
這篇文章主要來(lái)和探討一下關(guān)于MySQL表中沒(méi)有主鍵時(shí),該如何找到重復(fù)的數(shù)據(jù),文中的示例代碼講解詳細(xì),具有一定的參考價(jià)值,需要的可以了解一下2023-06-06通過(guò)實(shí)例判斷mysql update是否會(huì)鎖表
這篇文章主要介紹了通過(guò)實(shí)例判斷mysql update是否會(huì)鎖表,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-09-09如何使用mysql完成excel中的數(shù)據(jù)生成
這篇文章主要介紹了如何使用mysql完成excel中的數(shù)據(jù)生成的相關(guān)資料,需要的朋友可以參考下2017-11-11mysql 中 replace into 與 insert into on duplicate key update 的
這篇文章主要介紹了mysql 中 replace into 與 insert into on duplicate key update 的用法和不同點(diǎn),結(jié)合實(shí)例形式分析了replace into 與 insert into on duplicate key update的功能、基本用法與操作注意事項(xiàng),需要的朋友可以參考下2020-02-02MySQL優(yōu)化必須調(diào)整的10項(xiàng)配置
這篇文章主要介紹了MySQL優(yōu)化必須調(diào)整的10項(xiàng)配置,使用這些方法可以讓你快速地獲得一個(gè)穩(wěn)健的MySQL配置,需要的朋友可以參考下2014-02-02Mysql復(fù)制表結(jié)構(gòu)、表數(shù)據(jù)的方法
這篇文章主要介紹了Mysql復(fù)制表結(jié)構(gòu)、表數(shù)據(jù)的方法,需要的朋友可以參考下2015-10-10