数据表损坏的修复方法(终极完美版!!!!!)[转]

数据表损坏的修复方法(终极完美版!!!!!)[转]
原文地址: http://x.discuz.net/183161/viewspace-16039.html


由于 MySQL 本身的读写及锁定机制等方面的原因,与一些其他数据库软件一样,在特殊情况下的极为频繁读写时,或在服务器掉电、死机等情况下,相关的数据文件可能会发生被损坏的情况,通常可以采用以下的方式加以解决。
.l0E-UQyEO0 SupeSite/X-Space官方站8Eh-S:Cn Nx gs(N
一:repair.php 修复工具
o^7rU V-uQ0Discuz! 自带了一个使用 PHP 编写的数据表修复工具 repair.php,虚拟主机用户也可使用。该工具位于软件包的 ./utilities 目录中,使用时需要上传到服务器上论坛目录(注意不要连 ./utilities 目录一起上传,否则无法运行),
Sj;btNK9u0
1X"|4m&i?6Z v-NmV0upload.jpg SupeSite/X-Space官方站]] Jj.G"^
在浏览器运行后点击下面的链接即可
Rx(m-qy0 SupeSite/X-Space官方站7C3K{~ n%E)c-G"WB
run.jpg SupeSite/X-Space官方站_N'C _b
SupeSite/X-Space官方站q4l8l q u C%[K
修复以后如果出现下面的画面表示修复成功!!! SupeSite/X-Space官方站G iv`*X

aM@5A z n'\ ez*A0 SupeSite/X-Space官方站0L `C ZQF0s^-Y
result.jpg
'qb _H!Q4t)['^/e0这个工具能修复大多数常见的数据库错误,尤其是错误号为 126、127 的错误,对 145 错误也可修复,同时能对数据表在修复之后进行优化。如果一次修复不成功,可以尝试多次,或将数据库重启后再试。
_~yFxm0
3P` w:e G9S,t2m)V0 SupeSite/X-Space官方站G)Y+N$|:p[J-|*{I&c7e
SupeSite/X-Space官方站[@N*AfS
二 :myisamchk 修复工具 SupeSite/X-Space官方站E)?E/?F5S&o
MySQL 自带了专门用户数据表检查和修复的工具——myisamchk,当 repair.php 多次修复均无法成功时,可以在服务器终端使用 myisamchk 进行修复。在 MySQL 的程序文件目录(见《数据备份与恢复》中的说明)可以找到这个工具。 SupeSite/X-Space官方站+k[n+Vq KYW

J6g;oB%fy;gG@0常用的修复命令为 myisamchk -r 数据文件目录/数据表名.MYI,如果 -r 参数不能奏效,可以先把数据文件备份(备份可使用直接文件复制的方式,详见《数据备份与恢复》中的说明)后使用 -o 参数,如果-o还不可以的话,就使用-f参数,如果还是无法修复,只有使用你的备份文件来恢复数据了!什么??你没有备份文件 那你就坐到那里哭吧!!开个玩笑,但是网站及时的做备份确实是很重要的,尤其当有一定的规模以后,建议每天都做备份!! SupeSite/X-Space官方站'^9I J n1?8f!j&w xp:}
下面说一下具体的步骤: SupeSite/X-Space官方站)[#R"^w}
1. SupeSite/X-Space官方站r RG'^7^-t+XuO

gEVu7B} jK0cmd.jpg SupeSite/X-Space官方站r sFS(V.?rH
2.更改当前目录到mysql/bin下面,一般情况下只有在这个下面才能运行myisamchk命令
;E-}&xJ ^n-V2Q9W#T0 SupeSite/X-Space官方站L5I&ry R4y:j#}+w$[
SupeSite/X-Space官方站-er5f/?8EB'q0m`
myisamchk.jpg SupeSite/X-Space官方站GN,}7f5C*V
3.修复的结果,如果修复后的情况都如下图所示的话,你就可以 了,成功了,继续开启你的网站,运行吧!! SupeSite/X-Space官方站UncL.f4f+X t

_0O"}}&uY0}0|0 SupeSite/X-Space官方站p'EwS6@#J L
theresult.jpg SupeSite/X-Space官方站7u'?5U ~GK+Z6rU1E(t
4.别忘了启动你的mysql,要不你的网站还是运行不起来.
Dr3C1E}BR)e"X)G0 SupeSite/X-Space官方站Kl.J:n4v+Ha
SupeSite/X-Space官方站x$[/Vh^
startmysql.jpg
](e1O{+B5E-s1}!f0ps:下面给的一个是linux下面的修复方法,和上面的基本相同.只是linux下面关闭和启动mysql的方法和windows的不同.一般情况下linux用
O3o0].S2EE S0 SupeSite/X-Space官方站@7Dy o!R G$u Y
CODE:
[Copy to clipboard]
/etc/init.d/mysql stop  service mysqld stop /etc/init.d/mysql start service mysqld start
来关闭和启动mysql
f^Zi!y3v1S0
nB\aV&N0 SupeSite/X-Space官方站"x!@S"CH0c:`%b:S
linux.jpg
&j%r.O8~.^E w0o1R0
{&y7`'P9s"TG0另外 MySQL 官方文档中还提供了针对上面操作均无法奏效时的特殊办法,如先清空重建数据表,然后再用备份的数据文件覆盖等,这种特别复杂的情况用户通常不会碰到,因此这里不再做过于深入的研究。 SupeSite/X-Space官方站kH,M:It.s3nD
SupeSite/X-Space官方站ry O:D.x A|
三:数据表经常性损坏的解决方法 SupeSite/X-Space官方站W"Y$}y)B3O^

#DJu*ET\ AN5N0-------------------------------------------------------------------------------- SupeSite/X-Space官方站 U3m]5uOD-O6kD
SupeSite/X-Space官方站%|gj%s8G8fr6j
首先请确认在服务器硬件不存在问题(如内存工作不稳定、散热条件不好等),且使用中的操作系统版本也没有相关的 BUG 报告或升级补丁。这种情况下,如果数据库仍出现经常性的损坏,请检查是否 MySQL 的编译方式或参数存在问题。通常情况下使用官方提供的编译好的版本是比较稳定的,可以长期使用。如果您钟爱自行编译相关程序,请确认您的语言编译器(如 gcc)和配置的相关参数没有导致不稳定的因素。同时,磁盘分区满也可能是导致数据表经常性损坏的原因。网上提供了一些问题的处理方法(英文),需要时可多参考,并针对您的具体服务器环境制定解决方案。

你可能感兴趣的:(数据表损坏的修复方法(终极完美版!!!!!)[转])