MySQL启动报错[ERROR] InnoDB: Trying to access page number 4294967295 in space 0, space name innodb_syste

报错截图:

 Mysql不断的重启,innodb检查过不去。

解决办法: 

  1. 首先对数据目录全备份,docker备份挂载目录,服务器备份实际存储目录。
  2. 在mysql的配置文件里加入--innodb_force_recovery=0

###

/etc/my.cnf加入innodb_force_recovery=X行 X为0-6数字 0正常运行mysql 1(SRV_FORCE_IGNORE_CORRUPT):忽略检查到的corrupt页。

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

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

4(SRV_FORCE_NO_IBUF_MERGE):不执行插入缓冲的合并操作。 5(SRV_FORCE_NO_UNDO_LOG_SCAN):不查看重做日志,InnoDB存储引擎会将未提交的事务视为已提交。

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

如果几个数字挨个往后试,直到可以正常启动mysql。

如果还是不行可以尝试删除数据目录里ib_logfile*  ibdata*,一开始最好先不要删,最近一次解决过程中,删除后会导致你的表打不开,数据库无法备份。

###

然后保存,重启mysql(最好是先关闭再启动),看看是否可以启动。

  1. 如果可以启动进行下一步,备份数据库里的存放数据的库
mysqldump  -u用户名  -p密码  库名   >  库.sql

备份成功后,大致查看一下大小和里边是否有新建数据,插入数据的sql语句。

  1. 然后删除原数据库所有数据。(备份的不删),重新搭建数据库。导入备份好的数据。

首先需要上去检查是否有相应的库,如果没有需要手动先建库,不然会报错。

CREATE DATABASE  `name` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;

 #创建utf-8编码格式的库

mysql  -u用户名  -p密码   库名  < 库.sql

5、上去检查旧数据是否全部恢复。如果全部恢复,即修复完成。

###

如果碰到这个问题,一样可以解决

[ERROR] InnoDB: Ignoring the redo log due to missing MLOG_CHECKPOINT between the checkpoint

###

猜你喜欢

转载自blog.csdn.net/weixin_61299146/article/details/130622938