mysql奔溃后数据恢复

由于mysql系统经常出现无法启动(一般是由于服务器异常断电等原因),所以经常需要进行数据恢复,此文章系公司同事白宝奎所写,本人代为转发,希望能给需要的人带来一些帮助,文章如下

 

 

近日,有线上mysql数据库奔溃,所以记录了一下恢复步骤,亲测好用。

 

恢复步骤如下:

 

  1. 将错误的数据库备份出来,重新注册服务,等待使用

  1. 切换到mysql18088\data文件夹,在data文件夹里面找到多个mysql.bin.*格式的二进制文件,这些文件记录着mysql从注册到使用再到崩溃的所有sql语句,包括增删改查,commit,use等等操作的语句,先以修改日期排序这些文件,等待使用。此处需注意:排序后的文件名并不一定完全是有序的,详情见下图

  1. 以管理员身份运行cmd,cd到bin目录下,执行恢复语句,格式:mysqlbinlog -d 数据库名 --base64-output=DECODE-ROWS mysql-bin.*文件, mysql-bin.*文件,..... > 数据库名.sql,此处需要注意msql-bin.*的文件顺序很关键,比如:我要恢复2020.5.29到2020.6.29的数据,所以语句如下图所示:

 

执行成功后会生成sql文件,该sql文件就是这个数据库从创建到奔溃之间的所有语句,文件有大有小正常,因为每个库存储的量不一样。注:mysqlbinlog语句还有其它参数,其他用法可自行百度。

 

  1. 使用mysql工具恢复数据,工具有很多,我就用SQLyog来举例,如下图,导入文件,导入时,勾掉选项 “发生错误时退出”,执行导入操作。

 

  1. 执行完毕查看SQLyog错误日志,看是否有错误,如下图,用记事本打开,查看哪些语句执行有误

 

 

此外需要注意两点:

  1. 如果导入的数据库跟其它数据库有外键关系,那么要先确认关联的数据库数据要全,否则导入时会有一些外键冲突的语句报错,导致数据只成功恢复了一部分
  2. 乱码问题,生成sql文件前要先查看mysql文件夹下my.ini文件,查看编码格式是否是utf8,如果不是一定要修改,否则可能会出现乱码,my.ini添加四条语句如下:

default-character-set=utf8

character_set_server=utf8

default-storage-engine=innodb

collation-server=utf8_general_ci

修改完毕后,重启mysql服务即可

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL数据恢复是一个关键任务,特别是在数据丢失或系统故障的情况下。MySQL提供了几种方法来尝试恢复数据,包括: 1. **二进制日志(Binary Log)**:MySQL会记录所有对数据库的更改,如果在服务器意外关闭前,已经开启了二进制日志,可以通过binlog工具如`mysqlbinlog`来恢复到某个时间点的数据状态。 2. **InnoDB引擎的事务日志(Transaction Logs, ib_logfile*)**:InnoDB存储引擎有其自身的redo log和undo log,用于事务处理和恢复。可以通过检查和应用这些日志文件来还原因崩溃导致的数据。 3. **MyISAM或ARCHIVE引擎表的恢复**:这类表通常没有事务日志,但MyISAM表可以使用`myisamchk`工具进行检查和修复,而ARCHIVE表需要基于表结构重建数据。 4. **数据转储(Backup and Restore)**:定期备份数据库是最基本的防护措施,如果数据损坏,可以通过备份恢复到最近的一个完整备份点。 5. **第三方工具**:市面上有一些商业工具,如Percona XtraBackup、Navicat Data Recovery等,提供高级的数据恢复功能。 6. **物理文件操作**:如果严重到硬盘损坏,可能需要直接对.ibd文件(InnoDB表的数据文件)或frm文件(表结构文件)进行操作,但这通常仅限于非常高级的用户,且风险较高。 相关问题: 1. 如何启用MySQL的二进制日志? 2. InnoDB引擎的redo log和undo log分别用于什么? 3. 如何使用Percona XtraBackup进行数据恢复? 4. 对于MyISAM表的检查和修复,myisamchk有哪些常用选项? 5. 物理文件操作恢复数据的风险有哪些?

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值