记一次断电导致的mysql数据恢复问题
知识点掌握了,还需要不断练习才能熟练运用。下面golang学习网给大家带来一个数据库开发实战,手把手教大家学习《记一次断电导致的mysql数据恢复问题》,在实现功能的过程中也带大家重新温习相关知识点,温故而知新,回头看看说不定又有不一样的感悟!
最近在做监控系统选型,我们将监控系统分为两类:监控和追踪,本篇主要讲断电导致的服务器出现的问题以及解决方案,对于监控系统就不多做介绍了。市面上主流的监控系统主要是zabbix、open-falcon、promethues,今天的主角是zabbix,也就是这次是在搭建zabbix并监控jvm以及服务器信息之后出现的断电。
问题
1、服务器启动失败;
2、mysql启动失败;
经过
周五的时候搭建好了zabbix并且在持续运行,一切都正常,周日的时候突然断电导致服务器关机了,本想着重启一下服务器,登上去之后重新启动所有应用即可,结果却连服务器系统都进不去,直接提示进入紧急模式(当时没有截图截图,只能自行脑补了。。),根据提示输入journal查看到日志中提示sda3磁盘分区挂了。
服务器启动失败解决
知道是磁盘分区挂了,就很容易想到是磁盘在持续写入的时候突然断电导致的,那我们要做的就是对磁盘分区进行修复。对于xsf文件系统的修复很简单,出错的时候linux也会提示建议方案,我们只需要根据提示进行修复即可:
xfs_repair /dev/sda3
mysql启动失败
系统终于能够正常进入了,下一步就是启动应用了,对于zabbix,我安装的时候是基于mysql数据库去安装的,所以先启动mysql数据库,本来以为会一步到位,结果mysql又给了我当头一棒,直接启动失败,错误如下:

这个看不出来具体什么原因导致的,下一步去日志里看看,打开日志结果如下:

从日志中可以看出,断电的时候由于数据还在持续写入,所以数据损坏了,日志里也提到了解决方案:

于是打开该网址试试:

加这一行即可,通过资料查到这个是要加在mysql启动的配置文件my.cnf中,但是我找遍了各种路径也找不到my.cnf文件(查看命令:mysqld --verbose --help |grep -A 1 'Default options'),找dba帮我建了一个在etc目录下,加了如下内容:

经过搜索发现mysql不用my.cnf也能启动,只是会用默认值进行启动,而如果你想要覆盖mysql的默认行为,则可以通过my.cnf进行配置。这里把innodb_force_recovery改为1之后还是启动不了,不断往上加,一直到3才终于启动成功。但是这个参数可不是设置越大越好,他只是为了让你能先启动数据库,进行数据备份之类的操作,对于该参数的说明,我也截了一张图:

看到最后一行备注了吗,大于0的时候就无法进行更改类操作了,所以相当于还是没有用。
网上找了一圈,大体是无法正常使用了,只能先进行数据备份,然后删除坏表或者重建数据库。
在断电的时候,只有zabbix数据库是一直在使用的,所以第一个想到的是删除zabbix数据库(当然正常情况下我们也可以使用check table tableName来检查坏表),这样就删除了坏表了。执行删除操作

完了,删都删不掉,那只能采用重建数据库的操作了。
重建数据库
首先我们需要将所有数据导出来,这里写了一个脚本方便导出:
backupdir=/usr/local/mysql/dumpdir cd ${backupdir} cur_date=`date '+%Y%m%d'` if [ ! -d ${cur_date} ];then mkdir ${cur_date} fi cd ${cur_date} cur_time=`date '+%H%M%S'` db_names=(dbName1 dbName2 dbName3) for db_name in ${db_names[*]} do mkdir ${db_name} for table in `mysql -uroot -pyourpassword -e "show tables from ${db_name}" | sed '1d'` do mysqldump -uroot -pyourpassword ${db_name} ${table} >./"${db_name}"/${table}."${cur_time}".sql done done
通过运行以上shell脚本就能实现所有数据导出了。后面开始重建数据库:
1、手动删除mysql的data目录;
2、如果mysqld服务启着,则mysqld -remove MySQL进行移除;
3、mysqld --initialize-insecure,这一步mysql会自动创建新的data目录;
4、如果第二步移除掉,则这里需要再添加,mysqld --install;
5、如果启动的时候提示sock地址被占用,则先删除已存在的sock文件,比如我的sock文件是tmp/mysql.sock文件,当然把对应的sock.lock也一并删除了;
以上几步全部做完之后,启动mysql就成功了

下面开始创建用户
先用root用户直接登录(mysql -uroot),看一下目前的用户

4个用户,mysql8对于密码的认证方式默认使用caching_sha2_password,给root创建一个远程登录权限(我自己用的就是root远程登录),mysql8的话创建用户时记得加with mysql_native_password,如果你的客户端用的是mysql5的驱动。

ok,开始导入数据,同样也写了一个shell脚本进行导入。
for db in `ls /usr/local/dumpdir/20210324/`; do echo "source /usr/local/dumpdir/import/${db}.sql;" >> /usr/local/dumpdir/import.sql echo "CREATE DATABASE IF NOT EXISTS $db DEFAULT CHARSET utf8 COLLATE utf8_general_ci;" >> /usr/local/dumpdir/import/${db}.sql; echo "use ${db};" >> /usr/local/dumpdir/import/${db}.sql; for i in `ls /usr/local/dumpdir/20210324/${db}/` ; do echo "source /usr/local/dumpdir/20210324/${db}/$i;" >> /usr/local/dumpdir/import/${db}.sql; done done
登录mysql之后,运行以下命令执行导入操作:
source /usr/local/dumpdir/import.sql
到此为止,所有数据都恢复了,当然断电的时候丢失的那部分坏数据是没法恢复了。
最后给对应的用户分配指定数据库的权限就可以了。
附mysql相关脚本:
创建用户:create user 'user'@'host' with mysql_native_password identity by 'password';(8.0客户端不需要加with mysql_native_password)
给用户指定某表所有权限:grant all privileges on databaseName.* to targetUserName@"%";
总结
我们平时的生产环境还是要做好数据备份和数据库高可用,因为一旦出现断电这类问题,恢复时遇到的问题比较多而且造成的损失也很大。
参考资料
https://blog.csdn.net/theolds...
https://blog.csdn.net/edyf123...
https://blog.csdn.net/weixin_...
https://blog.csdn.net/qq_3659...
https://blog.csdn.net/zengxue...
https://www.bootwiki.com/note...
好了,本文到此结束,带大家了解了《记一次断电导致的mysql数据恢复问题》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多数据库知识!
-
- 陶醉的世界
- 太给力了,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,帮助很大,总算是懂了,感谢大佬分享文章内容!
- 2023-03-15 17:33:25
-
- 风中的往事
- 这篇博文真是及时雨啊,细节满满,写的不错,mark,关注up主了!希望up主能多写数据库相关的文章。
- 2023-03-13 13:14:17
-
- 数据库 · MySQL | 1天前 |
- MySQL设置中文界面,超简单教程来了!
- 332浏览 收藏
-
- 数据库 · MySQL | 1天前 | mysql 索引提示
- MySQL进阶必看!FORCE/USE/IGNOREINDEX用法大揭秘
- 182浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- 手把手教你写MySQL存储过程,小白也能轻松上手
- 163浏览 收藏
-
- 数据库 · MySQL | 1天前 | mysql group by
- MySQL分组查询优化:GROUPBY原理+索引优化超全解析
- 324浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQL设置中文语言,轻松拥有中文界面
- 211浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQL建库语句从入门到精通:创建数据库+设置字符集&排序规则(附实例)
- 176浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- 从零开始学MySQL数据库操作,小白轻松变大神!
- 496浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQL插入日期到时间字段,轻松搞定日期格式
- 484浏览 收藏
-
- 数据库 · MySQL | 1天前 | mysql 数据压缩
- MySQL怎么实现高效压缩存储?表压缩+列式存储详细解读
- 272浏览 收藏
-
- 数据库 · MySQL | 1天前 | mysql JOIN优化
- MySQL优化JOIN操作:七大技巧教你提升关联查询速度
- 106浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQL出现中文乱码?超详细解决方案一次性搞定
- 211浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQL主从复制这样配!搞懂这些参数,replication稳了~
- 131浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
-
- 茅茅虫AIGC检测
- 茅茅虫AIGC检测,湖南茅茅虫科技有限公司倾力打造,运用NLP技术精准识别AI生成文本,提供论文、专著等学术文本的AIGC检测服务。支持多种格式,生成可视化报告,保障您的学术诚信和内容质量。
- 18次使用
-
- 赛林匹克平台(Challympics)
- 探索赛林匹克平台Challympics,一个聚焦人工智能、算力算法、量子计算等前沿技术的赛事聚合平台。连接产学研用,助力科技创新与产业升级。
- 50次使用
-
- 笔格AIPPT
- SEO 笔格AIPPT是135编辑器推出的AI智能PPT制作平台,依托DeepSeek大模型,实现智能大纲生成、一键PPT生成、AI文字优化、图像生成等功能。免费试用,提升PPT制作效率,适用于商务演示、教育培训等多种场景。
- 57次使用
-
- 稿定PPT
- 告别PPT制作难题!稿定PPT提供海量模板、AI智能生成、在线协作,助您轻松制作专业演示文稿。职场办公、教育学习、企业服务全覆盖,降本增效,释放创意!
- 53次使用
-
- Suno苏诺中文版
- 探索Suno苏诺中文版,一款颠覆传统音乐创作的AI平台。无需专业技能,轻松创作个性化音乐。智能词曲生成、风格迁移、海量音效,释放您的音乐灵感!
- 57次使用
-
- golang MySQL实现对数据库表存储获取操作示例
- 2022-12-22 499浏览
-
- 搞一个自娱自乐的博客(二) 架构搭建
- 2023-02-16 244浏览
-
- B-Tree、B+Tree以及B-link Tree
- 2023-01-19 235浏览
-
- mysql面试题
- 2023-01-17 157浏览
-
- MySQL数据表简单查询
- 2023-01-10 101浏览