innodb引发的mysql数据库崩溃恢复

简单记录一下遇到的innodb引发的mysql数据库崩溃问题的处理过程

一、问题排查

1、问题现象

数据库连不上,发现服务端没起来

2、终端排查

指令:sudo systemctl status mysql.service

结果:报错

指令:sudo systemctl start mysql.service

结果:失败

指令:

3、查看日志

日志位置:/var/log/masql/error.log

查看方法: sudo vi error.log 或 sudo gedit error.log

结果:发现innodb崩溃

二、强行启动

1、my.conf

位置:etc/mysql/my.cnf

用途:配置文件

2、innodb_force_recovery

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):不执行前滚的操作。

当设置innodb_force_recovery大于0后,可以对标进行select、create、drop操作,但insert、update或者delete这类操作不允许执行。

3、修改并尝试启动

格式:

my.conf文件内添加:

[mysqld]

innodb_force_recovery = 1~6

逐步增大,直到成功启动mysql

修改指令:sudo vi/gedit my.cnf

启动命令:sudo systemctl start mysql.service

三、排除问题

1、备份数据库

mysqldump -uroot -ppassword databasename > databasename.sql

2、删除数据库

进入mysql:mysql -uroot -ppassword

查看数据库:show databases

删除数据库:drop databasename

3、无法通过指令删除时强制删除数据库

数据库一般位置:/var/lib/mysql/databasename

4、删除ib文件

备份后删除 ib_logfile0 ib_logfile1 ibdata1

位置 /var/lib/mysql

5、修改设定值

innodb_force_recovery 该为0或直接注释或删除

四、恢复数据

1、重启mysql

sudo systemctl start mysql.service

2、恢复数据

把备份的sql文件导回去

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

well_fly

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值