【数据库支持】mysql意外中断后,服务无法打开的解决

数据库无法重启的原因是因为ibdata1文件损坏,重启后无法正常恢复。

1、利用以下方法先屏蔽检查,启动服务

2、启动后备份数据

3、取消屏蔽检查

4、然后重新初始化一个mysql,再把备份的数据导入,即可

解决办法:

需要跳过恢复步骤,修改my.ini文件,在my.ini中的[mysqld]中添加:

innodb_force_recovery = 6

innodb_purge_threads = 1

解释:

innodb_force_recovery可以设置为1-6,大的数字包含前面所有数字的影响。

具体数字对应的含义:

1-----(SRVFORCEIGNORECORRUPT):忽略检查到的corrupt页。

2-----(SRVFORCENOBACKGROUND):阻止主线程的运行,如主线程需要执行full purge操作,会导致crash。

3-----(SRVFORCENOTRXUNDO):不执行事务回滚操作。

4-----(SRVFORCENOIBUFMERGE):不执行插入缓冲的合并操作。

5-----(SRVFORCENOUNDOLOGSCAN):不查看重做日志,InnoDB存储引擎会将未提交的事务视为已提交。

6-----(SRVFORCENOLOG_REDO):不执行前滚的操作。

再次启动mysql就ok了~

你可能感兴趣的:(技术支持,mysql,数据库,java)