主页 > 知识库 > mysql利用mysqlbinlog命令恢复误删除数据的实现

mysql利用mysqlbinlog命令恢复误删除数据的实现

热门标签:武汉网络外呼系统服务商 电话外呼系统改号 外呼系统打电话上限是多少 曲靖移动外呼系统公司 百应电话机器人优势 怎样在地图标注销售区域 啥是企业400电话办理 南昌三维地图标注 地图标注费用是多少

实验环境:

MYSQL 5.7.22 

开启二进志日志

日志格式MIXED

实验过程:

1、执行:FLUSH LOGS;

master-bin.000014 文件就是新生成的文件

刷新日志是为了实验内容更直观,更容易观察到整个实验过程的内容。

我看到网上许多文章有在用REST MASTER;而未说明此命令的严重性

这条命令会删除所有日志文件,并将文件名和记录点进行重置归零,99%的情况下是用不到这条命令的

删除日志可以用PURGE MASTER LOGS...这样保险一点

2、新日志文件已经生成,先观察一下内容,有几个点需要了解

 查看二进日日志文件命令:mysqlbinlog master-bin.000014

# at 4
#180903 16:19:12 server id 1 end_log_pos 123 CRC32 0xe03659b3 Start: binlog v 4, server v 5.7.22-log created 180903 16:19:12

先看上边两个箭头:

  • # at 4(事件开始点)
  • #180903 16:19:12 (代表的是时间)
  • server id 1(主备复制时需要为每个MYSQL数据库指定唯一的SERVER ID,我的未配置,默认是1)
  • end_log_pos 123(事件结束点)

再看下边两个箭头:

  • # at 123(事件开始点,和上边的事件结束点是对应的)
  • end_log_pos 154(事件结束点)
  • at 4 和 at 123之间的内容就是事件内容

3、模拟业务场景,建表,插入数据,最后将某个表删除;为了真实,我建了两个库,同时向不同的库写入内容,最后将其中一个库中的某个表删除。

mysql> FLUSH LOGS;
Query OK, 0 rows affected (0.01 sec)

mysql> create database t1;
Query OK, 1 row affected (0.03 sec)

mysql> create database t2;
Query OK, 1 row affected (0.00 sec)

mysql> use t1;
Database changed
mysql> create table t1 (id int);
Query OK, 0 rows affected (0.03 sec)

mysql> use t2;
Database changed
mysql> create table t2 (id int);
Query OK, 0 rows affected (0.03 sec)

mysql> insert into t2 values (3);
Query OK, 1 row affected (0.01 sec)

mysql> insert into t2 values (4);
Query OK, 1 row affected (0.01 sec)

mysql> use t1;
Database changed
mysql> insert into t1 values (1);
Query OK, 1 row affected (0.01 sec)

mysql> insert into t1 values (2);
Query OK, 1 row affected (0.01 sec)

mysql> use t2;
Database changed
mysql> insert into t2 values(20);
Query OK, 1 row affected (0.01 sec)

mysql> use t1;
Database changed
mysql> insert into t1 values(10);
Query OK, 1 row affected (0.01 sec)

mysql> drop table t1;
Query OK, 0 rows affected (0.02 sec)

mysql> use t2;
Database changed
mysql> insert into t2 values(222);
Query OK, 1 row affected (0.01 sec)

mysql>

建立T1、T2库,建立T1、T2表。

向T1插入数据:1、2、10

向T2插入数据:3、4、20、222

模拟场景,删除T1表,T2库T2表业务还在继续运行

现在将要通过日志将T1表进行恢复。

首先要先找到那个删除命令的日志点:

mysqlbinlog master-bin.000014|grep -5a "DROP TABLE" 

看到#AT 2439 (记下这个数字)

在这个事件点执行的DROP TABLE操作。

由于日志文件内不只有T1库的日志,还有T2库的日志,一会只取T1数据库的日志

而且还只取2439日志点之前的日志,再进行重新应用

如果把2439的日志取的话,再应用时数据库会重新建库建表,插数据, 还会执行这条删表语句。

 mysqlbinlog -d t1 --stop-position=2439  master-bin.000014>test.sql(执行这条语句竟然报错了)

WARNING: The option --database has been used. It may filter parts of transactions, but will include the GTIDs in any case. If you want to exclude or include transactions, you should use the options --exclude-gtids or --include-gtids, respectively, instead.
暂时弄不清楚原因,百度了下修改成:

mysqlbinlog master-bin.000014 -d t1 --skip-gtids --stop-position=2439>test.sql

-d:参数是指定某个数据库日志 

命令意思是将master-bin.000014日志文件内的T1数据库日志,事件点2439之前的日志,输出到test.sql

# tail test.sql

看看文件最后几行

登录数据库:

mysql> use t1;
Database changed

mysql> source test.sql

中间报错了一次,因为里边包含建库T1语句。

再查看表内容

这样数据就回来了。

到此这篇关于mysql利用mysqlbinlog命令恢复误删除数据的实现的文章就介绍到这了,更多相关mysql mysqlbinlog恢复误删除内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
  • MySQL命令无法输入中文问题的解决方式
  • MySQL命令行操作时的编码问题详解
  • MySQL source命令的使用简介
  • mysql常用sql与命令之从入门到删库跑路
  • MySQL存储过程的查询命令介绍
  • MySQL数据库自动补全命令的三种方法
  • mysql密码中有特殊字符&在命令行下登录的操作
  • Mysql桌面工具之SQLyog资源及激活使用方法告别黑白命令行
  • mysql的登陆和退出命令格式
  • MySQL如何使用授权命令grant
  • MySQL 基础常用命令总结

标签:黑河 锦州 沧州 资阳 随州 荆州 吉林 甘南

巨人网络通讯声明:本文标题《mysql利用mysqlbinlog命令恢复误删除数据的实现》,本文关键词  mysql,利用,mysqlbinlog,命令,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《mysql利用mysqlbinlog命令恢复误删除数据的实现》相关的同类信息!
  • 本页收集关于mysql利用mysqlbinlog命令恢复误删除数据的实现的相关信息资讯供网民参考!
  • 推荐文章