MYSQL数据表损坏的分析.docVIP

  1. 1、本文档共4页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
MYSQL数据表损坏的分析

文档编号: MYSQL数据表损坏的分析 <1.0> 作 者: 王黎晓 完成日期: 2006-12-20 修改情况记录: 版本号 修改人 修改日期 审核人 批准人 备注 1.0-draft 王黎晓 2006-12-20 创建 增加检查办法 我们运行一个cron任务,每小时检查我们所有重要的表,在FC5“crontab”文件中使用这样的行: 1 * * * * /usr/bin/myisamchk -s /var/lib/mysql/cef_push/*.MYI /var/sync/log/mysql-check.log 在solaris 9“crontab”文件中使用这样的行: 1 * * * * /usr/local/mysql/bin/myisamchk -s /usr/local/mysql/var/cef_push /*.MYI /var/sync/log/mysql-check.log 这打印出损坏的表的信息,因此我们能检验并且在需要时修复他们。 崩溃恢复 停掉mysql,再检查。 一张损坏的表的症状通常是查询意外中断并且你能看到例如这些错误: “tbl_name.frm”被锁定不能改变。 不能找到文件“tbl_name.MYI”(Errcode :### )。 从表处理器的得到错误###(此时,错误135是一个例外)。 意外的文件结束。 记录文件被毁坏。 在这些情况下,你必须修复表。myisamchk通常能检测并且修复出错的大部分东西。 修复过程包含最多4个阶段,在下面描述。在你开始前,你应该cd到数据库目录和检查表文件的权限,确保他们可被运行mysqld的Unix用户读取(和你,因为你需要存取你正在检查的文件)。如果它拒绝你修改文件,他们也必须是可被你写入的。 阶段1:检查你的表 运行myisamchk *.MYI或(myisamchk -e *.MYI,如果你有更多的时间)。使用-s(沉默)选项禁止不必要的信息。 你必须只修复那些myisamchk报告有一个错误的表。对这样的表,继续到阶段2。 如果在检查时,你得到奇怪的错误(例如out of memory错误),或如果myisamchk崩溃,到阶段3。 舞台 2 :简单安全的修复 首先,试试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 DELETE FROM tbl_name; mysql quit 将老的数据文件拷贝到新创建的数据文件之中。(不要只是将老文件移回新文件之中;你要保留一个副本以防某些东西出错。) 回到阶段2。现在myisamchk -r -q应该工作了。(这不应该是一个无限循环)。 阶段4:非常困难的修复 只有描述文件也破坏了,你才应该到达这个阶段。这应该从未发生过,因为在表被创建以后,描述文件就不再改变了。 从一个备份恢复描述文件并且回到阶段3。你也可以恢复索引文件并且回到阶段2。对后者,你应该用myisamchk -r启动。 如果你没有一个备份但是确切地知道表是怎样被创建的,在另一个数据库中创建表的一个拷贝。删除新的数据文件,然后从其他数据库将描述和索引文件移到破坏的数据库中。这给了你新的描述和索引文件,但是让数据文件独自留下来了。回到阶段2并且尝试重建索引文件。 参考资料 《MySQL中文参考手册-维护MySQL安装》

文档评论(0)

cuotian + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档