系统崩溃后,关于MYSQL恢复数据库的问题!求救啊!

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了系统崩溃后,关于MYSQL恢复数据库的问题!求救啊!相关的知识,希望对你有一定的参考价值。

WIN2008系统崩溃了,mysql没有来得及备份最新数据,但是数据库是安装在D盘的,所有文件都在。
重装系统后,对D盘原MYSQL目录进行重命名,然后全新安装MYSQL(版本一致,路径也一致),接着STOP MYSQL服务,最后复制原来的MYSQL目录下的所有文件(包括数据库文件)至新安装的目录,START MYSQL服务。
这样操作对么?为啥我这样操作后,SHOPEX在后台老是提示数据库错误,而且无法修复,还丢了一些数据。请问各位高手,应该怎么处理
phpmyadmin登陆,查看表
提示
错误
SQL 查询:

SHOW FULL FIELDS FROM `sdb_goods` ;

MySQL 返回:

#1033 - Incorrect information in file: '.\hznzcn\sdb_goods.frm'

使用mysqlcheck修复 提示:
D:\server\mysql\data\hznzcn>mysqlcheck -a -c -o -r hznzcn -u root -p
Enter password: **********
hznzcn.sdb_delivery_item
Error : Unknown table engine ''
error : Corrupt
hznzcn.sdb_dly_area
Error : Incorrect information in file: '.\hznzcn\sdb_dly_area.frm'
error : Corrupt

还有很多一样的ERROR,啥问题?hznzcn是库名

MySQL 在崩溃恢复时,会遍历打开所有 ibd 文件的 header page 验证数据字典的准确性,如果 MySQL 中包含了大量表,这个校验过程就会比较耗时。 MySQL 下崩溃恢复确实和表数量有关,表总数越大,崩溃恢复时间越长。另外磁盘 IOPS 也会影响崩溃恢复时间,像这里开发库的 HDD IOPS 较低,因此面对大量的表空间,校验速度就非常缓慢。另外一个发现,MySQL 8 下正常启用时居然也会进行表空间校验,而故障恢复时则会额外再进行一次表空间校验,等于校验了 2 遍。不过 MySQL 8.0 里多了一个特性,即表数量超过 5W 时,会启用多线程扫描,加快表空间校验过程。
如何跳过校验MySQL 5.7 下有方法可以跳过崩溃恢复时的表空间校验过程嘛?查阅了资料,方法主要有两种:
1. 配置 innodb_force_recovery可以使 srv_force_recovery != 0 ,那么 validate = false,即可以跳过表空间校验。实际测试的时候设置 innodb_force_recovery =1,也就是强制恢复跳过坏页,就可以跳过校验,然后重启就是正常启动了。通过这种临时方式可以避免崩溃恢复后非常耗时的表空间校验过程,快速启动 MySQL,个人目前暂时未发现有什么隐患。2. 使用共享表空间替代独立表空间这样就不需要打开 N 个 ibd 文件了,只需要打开一个 ibdata 文件即可,大大节省了校验时间。自从听了姜老师讲过使用共享表空间替代独立表空间解决 drop 大表时性能抖动的原理后,感觉共享表空间在很多业务环境下,反而更有优势。
临时冒出另外一种解决想法,即用 GDB 调试崩溃恢复,通过临时修改 validate 变量值让 MySQL 跳过表空间验证过程,然后让 MySQL 正常关闭,重新启动就可以正常启动了。但是实际测试发现,如果以 debug 模式运行,确实可以临时修改 validate 变量,跳过表空间验证过程,但是 debug 模式下代码运行效率大打折扣,反而耗时更长。而以非 debug 模式运行,则无法修改 validate 变量,想法破灭。
参考技术A 根据描述来看,你的过程是正确的,没有问题,把原来你重命名的那些文件置于其他路径下,再让MYSQL重新尝试读取,类似MSSQL的附加数据库一样,你尝试一下。追问

不是很懂,是改MY.INI的DATADIR么?

参考技术B 数据库修复问题我觉得还是北京的【达思数据库修复】比较专业,我以前也想找免费的软件修复,可事实却不是那么回事,很多所谓的数据恢复公司并不具备数据库修复技术能力。达思数据恢复公司是我知道的技术实力很强的公司··· 参考技术C 数据库名是否变化了
SHOPEX里配置的数据库名是否对应
丢了一些数据表存储类型是什么
参考技术D 奇怪的问题啊,难道你的表结构出问题了?联系我帮你免费看看。

参考资料:www.sql120.com

如何通过mysql的日志恢复数据库 加急求救

1、首先确定my.ini(Win系统)或my.cnf(Linux系统)是否有如下配置
[mysqld]
log-bin=mysql-bin
等号后面是文件名或者路径加文件名。
或者
用命令看是否开启binlog配置:
mysql> show master logs;
mysql> show binlog events g;
2、提供故障时点描述信息
3、如果开启了binglog那就可以按故障还原点或者时间点进行还原操作了
mysqlbinlog --start-position=
mysqlbinlog --start-datetime=
这里语法是进一步查询的线索,不知道你是什么OS、开发还是生产库?不能乱指挥。
【备份:做故障还原及数据恢复前切忌做好备份(数据文件以及日志文件)】
参考技术A 您好,很高兴为您解答。

要想通过日志恢复数据库,在my.cnf文件里应该有如下的定义,log-bin=mysql-bin,这个是必须的.binlog-do-db=db_test,这个是指定哪些数据库需要日志,如果有多个数据库就每行一个,如果不指定的话默认就是所有数据库.
[mysqld]
log-bin=mysql-bin
binlog-do-db=db_test
binlog-do-db=db_test2

删除二进制日志:
a.mysql> system ls -ltr /var/lib/mysql/bintest*;
mysql>reset master(清空所有的二进制日志文件)
b.purge master logs to 'bintest.000006';(删除bintest.000006之前的二进制日志文件)
c.purge master logs before '2007-08-10 04:07:00'(删除该日期之前的日志)
d.在my.cnf 配置文件中[mysqld]中添加:
expire_logs_day=3设置日志的过期天数,过了指定的天数,会自动删除

下面就是恢复操作了
特别提示,mysql每次启动都会重新生成一个类似mysql-bin.000003的文件,如果你的mysql每天都要重新启动一次的话,这时候你就要特别注意不要选错日志文件了。

可以看下这个:http://wenku.baidu.com/link?url=K4RYPxyNXo9gVJd3Rr-FBk4fWaz8I7v3M8U5zkvX6tE58h5kC2899w4tv1atq-KhYFfnzb7krZAEk-1kjC17Uas-8Kym3pudnF_eGMkz7Vi

如若满意,请点击右侧【采纳答案】,如若还有问题,请点击【追问】

希望我的回答对您有所帮助,望采纳!

~ O(∩_∩)O~

以上是关于系统崩溃后,关于MYSQL恢复数据库的问题!求救啊!的主要内容,如果未能解决你的问题,请参考以下文章

如何通过mysql的日志恢复数据库 加急求救

MySQL不启动后崩溃问题,怎么解决

求救!!关于映射网络驱动器的问题!!!谢谢啊!知道请告诉我啊!

pc崩溃后Xampp mysql innodb恢复失败

qt的程序异常退出 求救

MySQL崩溃恢复过程常见错误分析