crly-shell centos/windows服务器,Mysql数据库表结构损坏
【问题原因】服务器突然断电
【故障报告】数据库表结构损坏
【解决思路】进入强制恢复模式,备份库表及数据重建
故障发现
周末公司断电,周一启动数据库就直接报错了
查看日志
上面标记的log,明确表示是非正常关机(InnoDB: Database was not shutdown normally!)导致表结构损坏了,并且在最后给出了三种修复建议:
1)权限问题。我的文件无此类问题,略过该方案
2)跳过当前表恢复。我出错的表比较重要,全额无法通过备份恢复,所以该方案也不合适
3)调整强制恢复级别,强制修复表结构。我后续的处理,使用了选择了该方案。
备注:断电时往往数据结构都还是好的,只是mysql事务未完成,有坏的数据在这里,所以有错误。 理论上只要修复表结构、去除坏的数据,mysql就可以正常恢复了。
处理故障
如上所述,权衡之后,我采用了强制启动+导出数据重建的方式。
调整强制恢复级别
找到配置进入编辑模式:# vim /etc/my.cnf
在[mysqld]配置项下面配置(配置前需要检查,如果配置文件中已有该配置,将值改为6;如果没有则新增这项配置。)
配置文件中调整级别:(配置前需要检查,如果配置文件中已有该配置,将值改为6;如果没有则新增这项配置。)
因为之前也遇到过类似问题,低级别恢复失败了。所以我这里直接使用级别6:跳过启动检测直接进行库表重建。
如果是其他情况的启动异常,具体问题分析后再确定采用哪个级别。
innodb_force_recovery参数说明:
影响整个InnoDB存储引擎的恢复状况,默认值为0,表示当需要恢复时执行所有的恢复操作。 当不能进行有效的恢复操作时,MySQL有可能无法启动,并记录下错误日志。
innodb_force_recovery可以设置为1-6,大的数字包含前面所有数字的影响。 当设置参数值大于0后,可以对表进行select/create/drop操作,但insert/update/delete这类操作是不允许的。
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
配置改好后,就可以启动了。
启动方式选择常用的即可,但不能重复执行,否则提示进程已存在。
/etc/init.d/mysql start(在centos7.0以上版本已被systemctl start mysqld.service替代)
或者
service mysql start
正常启动后,注意此时我们只是跳过了启动检查,表数据仍然是坏的。新的数据读写操作进来,仍然可能会出错,甚至导致脏数据滚雪球般放大。因此需要修复数据
修复数据文件
修复数据采用的是导出后重建。
导出数据方式一
使用mysqldump命令导出:
如果数据顺利导出了,可以直接查看下一节重建。
导出数据方式二
使用navicat数据库连接工具远程连接数据库。
常见问题
提示密码过期
操作时出现了密码过期的提示:
尝试直接登录数据库后,没问题,但任何操作都会提示重设密码:
原因暂时不清楚,毕竟只是断电,没有数据库升级或其他动作。我直接按提示重设密码
能正常读了,接着执行备份:
执行命令:mysqldump -uroot -p --default-character-set=utf8 acc > ./acc.sql
输入密码,备份成功。
如果损坏的是MySQL系统表,无法dump
重建
此时数据已备份好,最大的风险已经没有了。
为了保险起见,接下来的操作前,可以把数据文件备份。
zip -r mysql_bak.zip /var/lib/mysql 或者直接将MySQL家目录改名(因为目前数据库已停止,不需要关闭数据库) mv /var/lib/mysql /var/lib/mysql_bak-user-date
有的人建议直接直接物理删除目录和里面的frm与ibd文件,找到mysql的data目录,找到目标库,删除整个目录,但是我没有成功。
我建议直接完全卸载mysql,直接重装数据库,因为我们现在最重要的数据已经备份出来了。这种方法百试不爽,从来没有失败过。
卸载数据库(注意使用脚本前修改相应的目录路径)
#!/bin/bash
#SelfDir
SelfDir=
(
c
d
"
(cd "
(cd"(dirname “
0
"
)
"
;
p
w
d
)
e
c
h
o
"
c
e
r
r
e
n
t
p
a
t
h
i
s
:
0")";pwd) echo "cerrent path is :
0")";pwd)echo"cerrentpathis:{SelfDir}”
mysql=‘mysql’
if [ rpm -qa | grep -i $mysql | wc -l
-ne 0 ]
then
echo " installed mysql "
service mysql stop
EXISTS_RPMS=rpm -qa | grep -i mysql
echo ${EXISTS_RPMS}
for RPM in ${EXISTS_RPMS}
do
rpm -e --nodeps ${RPM}
done
删除残留文件
rm -fr /usr/lib/mysql
rm -fr /usr/include/mysql
rm -f /etc/my.cnf
rm -fr /var/lib/mysql
rm -f /root/.mysql_secret
else
echo “start install mysql …”
fi
echo ‘finished!’
重装MYSQL(这里就不演示了,需要安装之前部署的mysql版本,可以在网上查mysql安装部署)
导入备份数据
将my.cnf中的innodb_force_recovery配置改为0或直接删掉(无该配置项时MySQL默认为0)
然后重建数据库
成功完成还原。
启动应用服务正常,数据库访问正常。
整个恢复过程基本完成。
windwos服务器的恢复流程与上述一样,只是服务的启停方式,文件后缀名,卸载安装操作不一样而已
windwos启停mysql net start/stop mysql或者到“服务”中启动,停止
windwos配置文件 my.ini
相关文章
- 万字总结:学习MySQL优化原理,这一篇就够了!
- 【MySql】mysql 表的常规管理
- linux - mysql - 卸载:RPM包安装方式的MySQL卸载
- 第二百八十七节,MySQL数据库-条件语句、循环语句、动态执行SQL语句
- centos中添加php扩展pdo_mysql步骤
- 合理使用mysql中的load data infile导入数据
- Centos中安装PHP的PDO MySQL扩展的教程
- 一天一个mysql函数(一) cast && convert
- Java通过mysql-connector-java-8.0.11连接MySQL Server 8.0遇到的几个问题
- MySQL -- 单行函数
- Centos设置开机启动Apache和Mysql[总结]
- PHP连接MySQL数据库的三种方式(mysql、mysqli、pdo)--续
- CentOS 6.5 安装 MySQL 5.6.17 并修改MySQL的root用户密码
- MySQL中的group_concat函数
- 数据库基础之Mysql(3)mysql删除历史binlog
- SSCursor in MySQL
- MySQL事务隔离级别理解_解读MYSQL的可重复读、幻读及实现原理
- centos下 Apache、php、mysql默认安装路径
- Starting MySQL. ERROR! The server quit without updating PID file (/data/mysql/mysql.pid).
- Atitit mysql 数据类型 5.7.9 目录 1.1. 数值类型1 2. 字符串2 3. 时间日期2 4. 地理位置2 5. 几何数据的存储,生成,分析,优化。 空间数据类型(存储)
- 揪出MySQL磁盘消耗迅猛的真凶
- 如何在windows上安装centos单系统,以及安装事项和 centOS Linux和centOS Stream区别
- 上Mysql com.mysql.jdbc.StatementImpl$CancelTask内存泄漏问题和解决方法
- centos 7 pip install MySQL-python 报错
- centos 6/7 tar包安装mysql 5.7
- MySQL超级简明基本操作攻略,给自己看(一)
- MySQL的分区、分表、集群
- Mysql修改表字段类型
- KVM虚拟机管理工作二(虚拟机磁盘优化,Centos进入dracut模式,报 /dev/centos/swap does not exist,如何恢复)