mysql数据恢复

使用MySQL第三方工具binlog2sql

binlog2sql,一款基于python开发的开源工具,是由大众点评团队的DBA使用python开发出来的,从MySQL
binlog解析出你要的SQL。根据不同选项,你可以得到原始SQL、回滚SQL、去除主键的INSERT SQL等。其功能有:

 数据快速回滚(闪回)
 主从切换后新master丢失数据的恢复
 从binlog生成标准SQL,带来的衍生功能

一、安装python
1、安装python3环境(Linux本省自带python2环境)
安装依赖:

yum install -y gcc gcc-c++ zlib zlib-devel libffi-devel openssl openssl-devel pcre pcre-devel yum-utils vim wget tree htop sqlite-devel

在这里插入图片描述
2、解压配置Python-3.6.5.tgz
安装
wget https://www.python.org/ftp/python/3.6.5/Python-3.6.5.tgz

tar -zxf  Python-3.6.5.tgz

配置安装参数

./configure --prefix=/usr/local/Python-3.6.5

在这里插入图片描述
编译安装

 make && make install

在这里插入图片描述
3、添加软链接,让python3和pip3这两个命令指向刚刚安装的python3.6

ln -s /usr/local/python3.6/bin/python3.7 /usr/bin/python3
ln -s /usr/local/python3.6/bin/pip3.7 /usr/bin/pip3

4、验证

python3 --version
pip3 --version

pip3 list 提示升级pip
在这里插入图片描述
python3 -m pip install --upgrade pip

二、安装binlog2sql

shell> git clone https://github.com/danfengcao/binlog2sql.git && cd binlog2sql
shell> pip install -r requirements.txt

再安装binlog2sql解析所需要的包
pip3 install mysql-replication-0.13.tar.gz
pip3 install PyMySQL-0.9.3.tar.gz
pip3 install wheel-0.34.2-py2.py3-none-any.whl
pip3 list
在这里插入图片描述
所用到的包在这里

https://download.csdn.net/download/weixin_44090237/88618756?spm=1001.2014.3001.5503

三、MySQL操作
1、进入MySQL确认是否开启binlog日志

show variables like 'log%'

如未开启,修改/etc/my.cnf文件,添加如下参数

[mysqld]
server_id = 1
log_bin = mysql-bin
binlog_format = row

添加完重启MySQL服务
systemctl restart mysqld
2、创建并删除测试数据
create table user;
insert into user ;
delete from user;
3、查看当前binlog文件

show master status;

四、解析出标准SQL

python3 binlog2sql.py -h127.0.0.1 -P3306 -uroot -p'123456' -dtest -t user --start-file='mysql-bin.000002'

在这里插入图片描述
五、解析出回滚SQL

根据时间解析

python3 binlog2sql.py --flashback -h127.0.0.1 -P3306 -uroot -p'123456' -dtest -t user --start-file='mysql-bin.000002' --start-datetime='2023-12-07 16:59:49' --stop-datetime='2023-12-11 11:17:20' > user.txt

在这里插入图片描述
六、还原sql

解析拿到的sql做处理
awk -F ‘;’ ‘{print $1 “;”}’ user .txt > user.txt
cat user.txt |grep “INSERT” > user.sql

最后回到MySQL
source user.sql

  • 13
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值