1. 表损坏的原因分析 以下原因是导致mysql 表毁坏的常见原因: 1、 站点服务器突然断电导致数据网站网站文件损坏。 2、 强制关机,没有先关闭mysql 服务。 3、 mysqld 进程在写表时被杀掉。 4、 使用myisamchk 的同时,mysqld 也在操作办法表。 5、 磁盘故障。 6、 站点服务器死机。 7、 mysql 本身的bug 。 2. 表损坏的症状 一个损坏的表的典型症状如下: 1 、当在从表中选择数据之时,您得到如下错误: Incorrect key file for table: '...'. Try to repair it 2 、查询不能在表中找到行或返回不完全的数据。 3 、Error: Table 'p' is marked as crashed and should be repaired 。 4 、打开表失败: Can’t open file: ‘×××.MYI’ (errno: 145) 。 5 、 3. 预防 MySQL 表损坏 可以采用以下手段预防mysql 表损坏: 1 、定期使用myisamchk 检查MyISAM 表(注意要关闭mysqld ),推荐使用check table 来检查表(不用关闭mysqld )。 2 、在做过大量的更新或删除操作办法后,推荐使用OPTIMIZE TABLE 来网站seo优化表,这样既减少了网站网站文件碎片,又减少了表损坏的概率。 3 、关闭站点服务器前,先关闭mysqld (正常关闭服务,不要使用kill -9 来杀进程)。 4 、使用ups 电源,避免出现突然断电的情况。 5 、使用最新的稳定发布版mysql ,减少mysql 本身的bug 导致表损坏。 6 、对于InnoDB 引擎,您可以使用innodb_tablespace_monitor 来检查表空间网站网站文件内网站网站文件空间管理的完整性。 7 、对磁盘做raid ,减少磁盘出错并提高性能。 8 、网站数据库站点服务器最好只跑mysqld 和必要的其他服务,不要跑其他业务服务,这样减少死机导致表损坏的可能。 9 、不怕万一,只怕意外,平时做好备份是预防表损坏的有效手段。 4. MySQL 表损坏的修复 MyISAM 表可以采用以下步骤进行修复 : 1、 使用 reapair table 或myisamchk 来修复。 2、 假如如果上面的具体相关方法修复无效,采用备份恢复表。 具体可以参考如下做法: 阶段1 :检查您的表 假如如果您有很多时间,运行myisamchk *.MYI 或myisamchk -e *.MYI 。使用-s (沉默)选项禁止不必要的信息。 假如如果mysqld 站点服务器处于宕机状态,应使用--update-state 选项来告诉myisamchk 将表标记为' 检查过的' 。 您必须只修复那些myisamchk 报告有错误的表。对这样的表,继续到阶段2 。 假如如果在检查时,您得到奇怪的错误( 例如out of memory 错误) ,或假如如果myisamchk 崩溃,到阶段3 。 阶段2 :简单安全的修复 注释:假如如果想更快地进行修复,当运行myisamchk 时,您应将sort_buffer_size 和Key_buffer_size 变量的值设置为可用内存的大约25% 。 首先,试试myisamchk -r -q tbl_name(-r -q 意味着“ 快速恢复模式”) 。这将试图不接触数据网站网站文件来修复索引网站网站文件。假如如果数据网站网站文件包含它应有的一切内容和指向数据网站网站文件内正确地点的删除连接,这应该管用并且表可被修复。开始修复下一张表。否则,执行下列过程: 在继续前对数据网站网站文件进行备份。 使用myisamchk -r tbl_name(-r 意味着“ 恢复模式”) 。这将从数据网站网站文件中删除不正确的记录和已被删除的记录并重建索引网站网站文件。 假如如果前面的步骤失败,使用myisamchk --safe-recover tbl_name 。安全恢复模式使用一个老的恢复具体相关方法,处理常规恢复模式不行的少数情况( 但是更慢) 。 假如如果在修复时,您得到奇怪的错误( 例如out of memory 错误) ,或假如如果myisamchk 崩溃,到阶段3 。 阶段3 :困难的修复 只有在索引网站网站文件的第一个16K 块被破坏,或包含不正确的信息,或假如如果索引网站网站文件丢失,您才应该到这个阶段。在这种情况下,需要创建一个新的索引网站网站文件。按如下步骤操做: 把数据网站网站文件移到安全的地方。 使用表描述网站网站文件创建新的( 空) 数据网站网站文件和索引网站网站文件: shell> mysql db_name mysql> SET AUTOCOMMIT=1; mysql> TRUNCATE TABLE tbl_name; mysql> quit 假如如果您的MySQL 版本没有TRUNCATE TABLE ,则使用DELETE FROM tbl_name 。 将老的数据网站网站文件拷贝到新创建的数据网站网站文件之中。(不要只是将老网站网站文件移回新网站网站文件之中;您要保留一个副本以防某些东西出错。) 回到阶段2 。现在myisamchk -r -q 应该工作了。(这不应该是一个无限循环)。 您还可以使用REPAIR TABLE tbl_name USE_FRM ,将自动执行整个程序。 阶段4 :非常困难的修复 只有.frm 描述网站网站文件也破坏了,您才应该到达这个阶段。这应该从未发生过,因为在表被创建以后,描述网站网站文件就不再改变了。 从一个备份恢复描述网站网站文件然后回到阶段3 。您也可以恢复索引网站网站文件然后回到阶段2 。对后者,您应该用myisamchk -r 启动。 假如如果您没有进行备份但是确切地知道表是怎样创建的,在另一个网站数据库中创建表的一个拷贝。删除新的数据网站网站文件,然后从其他网站数据库将描述网站网站文件和索引网站网站文件移到破坏的网站数据库中。这样提供了新的描述和索引网站网站文件,但是让.MYD 数据网站网站文件独自留下来了。回到阶段2 并且尝试重建索引网站网站文件。 InnoDB 表可以采用下面的具体相关方法修复: 假如如果网站数据库页被破坏,您可能想要用SELECT INTO OUTFILE 从从网站数据库转储您的表,通常以这种具体相关方法获取的大多数数据是完好的。即使这样,损坏可能导致SELECT * FROM tbl_name 或者InnoDB 后台操作办法崩溃或断言,或者甚至使得InnoDB 前滚恢复崩溃。 尽管如此,您可以用它来强制InnoDB 存储引擎启动同时阻止后台操作办法运行,以便您能转储您的表。例如:您可以在重启站点服务器之前,在选项网站网站文件的[mysqld] 节添加如下的行: [mysqld]innodb_force_recovery = 4innodb_force_recovery 被允许的非零值如下。一个更大的数字包含所有更小数字的预防措施。假如如果您能够用一个多数是4 的选项值来转储您的表,那么您是比较安全的,只有一些在损坏的单独页面上的数据会丢失。一个为6 的值更夸张,因为网站数据库页被留在一个陈旧的状态,这个状态反过来可以引发对B 树和其它网站数据库结构的更多破坏。 1 (SRV_FORCE_IGNORE_CORRUPT) 即使站点服务器检测到一个损坏的页,也让站点服务器运行着;试着让SELECT * FROM tbl_name 跳过损坏的索引记录和页,这样有助于转储表。 2 (SRV_FORCE_NO_BACKGROUND) 阻止主线程运行,假如如果崩溃可能在净化操作办法过程中发生,这将阻止它。 3 (SRV_FORCE_NO_TRX_UNDO) 恢复后不运行事务回滚。 4 (SRV_FORCE_NO_IBUF_MERGE) 也阻止插入缓冲合并操作办法。假如如果您可能会导致一个崩溃。最好不要做这些操作办法,不要计算表统计表。 5 (SRV_FORCE_NO_UNDO_LOG_SCAN) 启动网站数据库之时不查看未完成日志:InnoDB 把未完成的事务视为已提交的。 6 (SRV_FORCE_NO_LOG_REDO) 不要在恢复连接中做日志前滚。 网站数据库不能另外地带着这些选项中被允许的选项来使用。作为一个安全措施,当innodb_force_recovery 被设置为大于0 的值时,InnoDB 阻止用户执行INSERT, UPDATE 或DELETE 操作办法. 即使强制恢复被使用,您也可以DROP 或CREATE 表。假如如果您知道一个给定的表正在导致回滚崩溃,您可以移除它。您也可以用这个来停止由失败的大宗导入或失败的ALTER TABLE 导致的失控回滚。您可以杀掉mysqld 进程,然后设置innodb_force_recovery 为3 ,使得网站数据库被挂起而不需要回滚,然后舍弃导致失控回滚的表。能备份mysql网站数据库的php具体相关代码(一个表一个网站网站文件)