检查被破坏的MySQL数据文件的方法

数据库 MySQL
由于终止MySQL服务进程等原因,MySQL数据文件有可能遭到破坏,下面就教您一个检查被破坏的MySQL数据文件的方法,供您参考。

MySQL数据文件如果损坏,如何检查呢?这可能是很多人都遇到过的难题。不要紧,下面就教您检查被破坏的MySQL数据文件的方法。

由于临时断电,使用kill -9中止MySQL服务进程,所有的这些都可能会毁坏MySQL数据文件。如果在被干扰时,服务正在改变文件,文件可能会留下错误的或不一致的状态。因为这样的毁坏有时是不容易被发现的,当你发现这个错误时可能是很久以后的事了。于是,当你发现这个问题时,也许所有的备份都有同样的错误。

MySQL参考手册的第十五章讲述了MySQL自带的myisamchk的功能,以及如何使用它检查和修复你的MySQL数据文件。虽然这一章对于每个想要搭建一个强壮的MySQL服务的人都是推荐阅读的,我们还是有必要在这里对其中的要点进行讨论。

在我们继续之前,你必须意识到myisamchk程序对用来检查和修改的MySQL数据文件的访问应该是唯一的。如果MySQL服务正在使用某一文件,并对myisamchk正在检查的文件进行修改,myisamchk会误以为发生了错误,并会试图进行修复--这将导致MySQL服务的崩溃!这样,要避免这种情况的发生,通常我们需要在工作时关闭MySQL服务。作为选择,你也可以暂时关闭服务以制作一个文件的拷贝,然后在这个拷贝上工作。当你做完了以后,重新关闭服务并使用新的文件取代原来的文件(也许你还需要使用期间的变更日志)。

MySQL数据目录不是太难理解的。每一个数据库对应一个子目录,每个子目录中包含了对应于这个数据库中的数据表的文件。每一个数据表对应三个文件,它们和表名相同,但是具有不同的扩展名。tblName.frm文件是表的定义,它保存了表中包含的数据列的内容和类型。tblName.MYD文件包含了表中的数据。tblName.MYI文件包含了表的索引(例如,它可能包含lookup表以帮助提高对表的主键列的查询)。

要检查一个表的错误,只需要运行myisamchk(在MySQL的bin目录下)并提供文件的位置和表名,或者是表的索引文件名:

myisamchk /usr/local/mysql/var/dbName/tblName

myisamchk /usr/local/mysql/var/dbName/tblName.MYI

上面的两个命令都可以执行对指定表的检查。要检查数据库中所有的表,可以使用通配符:

myisamchk /usr/local/mysql/var/dbName/*.MYI

要检查所有数据库中的所有表,可以使用两个通配符: myisamchk /usr/local/mysql/var/*/*.MYI

如果不带任何选项,myisamchk将对表文件执行普通的检查。如果你对一个表有怀疑,但是普通的检查不能发现任何错误,你可以执行更彻底的检查(但是也更慢!),这需要使用--extend-check选项:

myisamchk --extend-check /path/to/tblName

对错误的检查是没有破坏性的,这意味着你不必担心执行对你的数据文件的检查会使已经存在的问题变得更糟。另一方面,修复选项,虽然通常也是安全的,但是它对你的数据文件的更改是无法撤消的。因为这个原因,我们强烈推荐你试图修复一个被破坏的表文件时首先做个备份,并确保在制作这个备份之前你的MySQL服务是关闭的。


 

 

【编辑推荐】

10大常用MySQL命令行

7个常见的MySQL命令行

MySQL权限表的介绍

MySQL用户权限的取消

MySQL修改表结构语句介绍

责任编辑:段燃 来源: 互联网
相关推荐

2010-10-29 14:03:39

Oracle移动数据文

2010-10-13 14:02:01

MySQL数据文件

2022-12-01 14:02:02

MySQL数据文件

2010-10-13 11:19:11

MySQL数据文件

2010-09-13 16:06:48

sql server数

2010-07-13 14:09:07

SQL Server数

2010-06-10 14:14:18

个MySQL表索引

2013-08-07 10:04:37

MySQL数据恢复

2010-04-30 16:01:17

2017-08-25 17:41:17

Paradox数据文件格式

2011-08-11 09:56:49

2010-05-13 17:33:24

MySQL索引

2010-10-13 10:49:42

MySQL数据文件

2015-07-29 15:21:43

2010-11-24 14:03:28

mysql表索引

2010-04-27 14:18:56

Oracle控制文件

2012-01-05 10:03:23

2023-05-09 10:16:50

安全CIOIT

2014-11-27 13:59:34

OptimBluemixIBM

2010-06-09 13:47:31

MySQL直接备份数据
点赞
收藏

51CTO技术栈公众号