您当前的位置:首页>>技术中心>>数据恢复文章>>正文
 
精讲 MYSQL数据恢复

 

   来源:Watchstor.com   
    摘要:当用户错误地删除数据库或表时,或者错误地删除表的内容时。不论这些不幸的事件发生是由于什么原因,都需要MYSQL数据恢复操作。
   标签:MYSQL数据恢复


    MYSQL数据库毁坏发生的原因有许多,且程度各不相同。如果幸运的话,可能是一两个表的小毁坏(例如,如果您的机器由于断电而暂时停机)。如果不是这样,可能需要置换整个的数据目录(例如,如果某个磁盘瘫痪而且数据目录在它上)。在其他情况下也需要MYSQL数据恢复操作,例如,当用户错误地删除数据库或表时,或者错误地删除表的内容时。不论这些不幸的事件发生是由于什么原因,都需要MYSQL恢复它们。

    如果表被毁坏但没有丢失,可试着用myisamchk或isamchk来修复它们。如果修复实用程序能修复它们,就根本挥斜匾褂帽阜菸募1淼男薷垂探诘?3章讨论。如果表被丢失或不能修复,则需要恢复它们。

    MYSQL数据恢复过程包括两个信息源:备份文件和更新日志。备份文件将表恢复到进行该备份时的状态。但是,在备份和故障发生这段时间中,表通常已经被修改。更新日志包含了用来完成这些修改的查询。可以通过将更新日志作为对mysql的输入来重复这些查询(这就是为什么

    应该允许更新日志的原因。如果您还没有使更新日志有效,现在赶快做,并在进一步读取之前生成一个新的备份)。

    MYSQL数据恢复过程根据必须恢复的信息的多少而变化。事实上,恢复整个数据库比恢复单个的表要容易,因为对数据库应用更新日志比对表要容易。

    MYSQL数据恢复整个数据库

    首先,如果要恢复的数据库是含有授权表的mysql数据库,将需要使用--skip-grant-tables选项运行服务器。否则,服务器将抱怨无法找到授权表。在MYSQL数据恢复表之后,执行mysqladminflush-privileges来告诉服务器加载授权表,并用它们启动。

    将原数据库目录的内容拷贝到其他的地方。例如,您可能会在稍后用它们进行崩溃表的事后分析检查(post-mortemexamination)。

    用最新的备份文件重新加载数据库。如果您打算使用由mysqldump加载的文件,则需要将它们作为mysql的输入。如果打算使用从数据库中直接拷贝的文件(如,用tar或cp),则将它们直接拷贝回到该数据库目录中。但是,在这种情况下,应该在拷贝这些文件之前关闭服务器,然后再重新启动它。

    用更新日志重做在进行备份后又修改了数据库表的查询。对于所有可用的更新日志,可使用它作为mysql的输入。指定--one-database选项,使mysql只对想要MYSQL数据恢复的数据库执行查询。如果您知道需要使用所有的更新日志文件,可在包含日志的目录中使用

    下列命令:

    %ls-t-r-lupdate.(0-9)*|xargscat|mysql--one-    databasedb_name

    ls命令产生更新日志文件的单列列表,更新日志文件根据服务器生成的顺序进行排序(要知道,如果您修改了其中的任何文件,排序的顺序都将改变,这将导致更新日志按错误的顺序使用)。

    您很可能必须使用某些更新日志。例如,如果自备份以来所产生的日志命名为update.392、update.393等等,可以重新运行它们中的命令:

    %mysql--one-databasedb_name<updata.392

    %mysql--one-databasedb_name<updata.393

    如果正在运行恢复并打算使用更新日志恢复由于失策的DROPDATABASE、DROPTABLE或DELETE语句而丢失的信息,应确保先从更新日志中删除这些语句。

    MYSQL数据恢复单个的表

    恢复单个表是很困难的。如果有通过mysqldump生成的备份文件并且它恰好不包含您想要的表数据,则需要抽取相关的行并用它们作为mysql的输入,这部分较容易。困难的是抽取应用于该表的更新日志的片段。您会发现:mysql_find_rows实用程序对这方面有帮助,它可以从更新日志中抽取多行查询。

    另一种可能性是用另一个服务器MYSQL数据恢复整个数据库,然后将所要的该表的文件拷贝到原始数据库中。这实际很容易!在将文件拷贝回数据库目录时,应确保原始数据库的服务器关闭。

 


上一篇:数据恢复你自己也可以轻松搞定
下一篇:重复数据删除技术分类浅析
  北京总部: 4006-505-646
  天 津 部: 4006-505-646
  上 海 部: 4006-505-646
  深 圳 部: 4006-505-646
  广 州 部: 4006-505-646
  重 庆 部: 4006-505-646
  南 京 部: 4006-505-646
  其它地区: 4006-505-646
经典案例
中国石油管理局-Oracle数据库恢
中国网通-IBM EXP300磁盘阵列数
大连鸿德经贸有限责任公司-SQL
中国地质环境监测院-HP LH3000
藁城市东街百货-EFS文件解密成
工商银行某省分行-AIX删除LV数
中央电视台新闻评论部-苹果分
promise乔鼎硬盘阵列数据恢复成
麒麟童文化-苹果分区无法打开,
NAS 8100服务器数据恢复成功 
解决方案
raid磁盘阵列OFFLINE后的应急方
磁盘未被格式化,是否格式化数据
误GHOST、误一键恢复灾难应急方
误删除、误格式化数据灾难应急
LINUX FSCK数据出错灾难应急方
北亚数据恢复 - 联系我们 - 关于北亚 - 友情链接 - 网站地图 - RSS聚合 
版权所有 北京北亚宸星科技有限公司
全国统一客服热线:4006-505-646
北京总部:北京市海淀区永丰基地丰慧中路7号新材料创业大厦B座205室
eoay)