前言:
数据库无法启动是在运维中常见的问题,大多是重启服务器、磁盘损坏、配置不当导致的。建议您在面板计划任务中做个数据库全部备份的计划任务,这样在遇到问题的情况下可以及时通过备份进行恢复。
在根据下面的案例尝试恢复或者启动数据库前,记得做个磁盘快照,以免操作不当增加恢复难度甚至无法恢复。
正确的做法是:
1、关闭web服务和其他可以写入磁盘的服务
2、做好磁盘快照
3、根据案例的解决方案进行上手操作
4、如果您不会或者不懂怎么操作,可以联系我们官方客服(面板右下角有客服二维码)
案例一innodb_buffer_pool_size配置不当导致启动失败
1、出现原因
- 服务器可用内存不足,导致无法分配更多的内存给innodb_buffer_pool_size
- 服务器内存充足,但是配置参数过大导致无法分配更多的内存给innodb_buffer_pool_size
2、解决方案
登录到面板—软件商店—mysql管理界面—性能调整,选择与自己的服务器实际内存相匹配的内存大小,然后重启服务器
案例二、错误提示:InnoDB:Could not find a valid tablespace file for…
1、出现原因
- 断电造成服务器关机,开机启动后导致出现innodb存储引擎出现孤立表
- 删除表的时候,该表还在使用中,导致未能完全删除,造成损坏
- 进行事务回滚时候恢复失败
- 非正常关闭MySQL服务造成MySQL物理文件损坏,导致MySQL无法读取物理文件
- 其他问题导致
2、解决方案:
1、官方文档
https://dev.mysql.com/doc/refman/5.7/en/forcing-innodb-recovery.html
https://dev.mysql.com/doc/refman/8.0/en/forcing-innodb-recovery.html
2、论坛针对性的教程
https://www.bt.cn/bbs/thread-87521-1-1.html
注意:操作前一定要做个快照或者磁盘备份,避免操作不当导致专业的DBA也无法进行恢复
案例三、错误提示:Error in Log_event::read_log_event(): ‘Event too small’, data_len: e, event_type: 0
1、出现原因
- 数据库非正常关闭
- 切换了MySQL版本导致无法解析mysql的二进制日志
2、解决方案:
1、官方文档
https://dev.mysql.com/doc/refman/5.7/en/forcing-innodb-recovery.html
https://dev.mysql.com/doc/refman/8.0/en/forcing-innodb-recovery.html
2、论坛针对性的教程
https://www.bt.cn/bbs/thread-87521-1-1.html
注意,操作前一定要做个快照或者磁盘备份,避免操作不当导致专业的DBA也无法进行恢复
案例四、 错误提示:/bin/mysqld: Table ‘./mysql/user’ is marked as crashed and should be repaired
1、出现原因
- MySQL数据库使用的user表损坏导致的
2、解决方案
- 登录到服务器SSH终端里
- 使用命令:/www/server/mysql/bin/mysqlcheck -uroot -p数据库密码 mysql user
- 修复完后,会有提示mysql.user OK字样,然后重新启动mysql即可
案例五、错误信息:[ ERROR]Got error 127 when reading table …
1、出现原因
- 数据库在读取、写入数据的时候引起数据库文件损坏导致数据库表错误
2、解决方案
- 登录到MySQL命令行中
- use对应的数据库
- CHECK TABLE wp_options;
- REPAIR TABLE wp_options;
- 再次检查表,CHECK TABLE wp_options; 如果输出OK,代表已经修复完成
注意操作前一定做好数据库备份,最好个快照。以免操作不当增加数据库恢复难度。
案例六 、启动mysql的时候提示:File ‘./mysql-bin.000015’ not found (Errcode: 2 - No such file or directory)
1、出现原因
- 手动删除了数据库的二进制日志
- 二进制日志损坏,导致mysql无法读取二进制日志
- 其他问题
2、解决方案
- 打开/www/server/data/mysql-bin.index
- 删掉提示找不到的mysql-bin.000015
- 重启mysql
操作后可能还会出现其他binlog日志文件找不到的话,可以把mysql-bin.index中记录的二进制日志跟
/www/server/data/中的mysql-bin.xxxx对比,保留一致的mysql-bin.xxx日志文件; 如果
/www/server/data/已经没有了mysql-bin.xxxx的话,需要把mysql-bin.index记录的二进制文件全部删掉