MySql使用binlog日志恢复误删数据(强化)—— 筑梦之路

对于数据库误删数据恢复,推荐定期备份,通过定期备份的文件进行恢复,这里主要是使用binlog日志方式来恢复误删数据,之前也写过相关内容,这里再次强化一下步骤流程,增强熟悉程度。

概述

MySQL数据库可以开启binlog功能,记录数据库中每个操作的日志。可以通过解析binlog日志来找回误删除的操作。可以使用"mysqlbinlog"命令来解析binlog文件,并通过该命令生成的SQL语句进行数据恢复。

恢复流程

  • **1)**先使用备份数据恢复出全部备份的数据

  • **2)**使用binlog日志恢复出增量数据到误操作之前

恢复步骤过程

1. 创建测试表t2

bash 复制代码
# 创建表t2

create table t2(id bigint);

# 插入数据

insert into t2 values (1), (2), (3), (4);

# 查询

select * from t2;

# 再次插入数据

insert into t2 values (5), (6), (7), (8);

2. 数据库全备

bash 复制代码
mysqldump -p -d test --single-transaction --set-gtid
-purged=off --master-data=2 --flush-logs --routines --
triggers --events --extended-insert=true> test.sql



参数说明:
single-transaction

此选项会将隔离级别设置为:REPEATABLE READ。并且随后再执行一条START TRANSACTION语句,让整个数据在dump过程中保证数据的一致性,这个选项对InnoDB的数据表很有用,且不会锁表。但是这个不能保证MyISAM表和MEMORY表的数据一致性。

master-data=2  

在bin-log日志里记录备份到了哪个位置,比如说binlog名称,binlog位置。

set-gtid-purged=off

表示在备份时不输出跟 GTID 相关的信息。

flush-logs

命令的作用就是关闭当前使用的binary log,然后打开新的binary log文件,文件的序号加1。

extended-insert 

代表长INSERT,多row在一起批量INSERT提高导入效率。

routines,events,triggers

备份的时候将过程,函数,触发器,事件进行备份。

3. 增量数据插入

bash 复制代码
insert into t2 values (9), (10), (11), (12);

insert into t2 values (16), (15), (14), (13);

insert into t2 values (20), (19), (18), (17);


# 检查插入的数据

select count(*) from t2;

4. 删除test库

bash 复制代码
drop database test;

# 确认是否删除
show databases;

5. 恢复数据(全量+binlog)

bash 复制代码
create database test;

use test;

source test.sql;

# 检查数据

select * from t2;

此处使用全量备份的sql文件进行恢复,在备份之后的数据是没有的,因此我们需要使用binlog日志来恢复在全量备份之后插入的数据。

首先解析binlog文件,找到执行误操作的那条命令,他的事物号为787.记住该事物号,很重要!,很重要!很重要!

bash 复制代码
mysqlbinlog -uroot -p --start-position=154
/var/lib/mysql/mysql-bin.000002 --base64-output=decode-rows -vv



参数解释:
start-position:
日志开始位点,mysqlbinlog从哪个位点开始解析binlog日志.
stop-position
日志结束位点,mysqlbinlog到哪个位点结束解析binlog日志.

看到在mysql-bin.000002日志里面出现了drop database的操作

当前需要的是注释掉解析出的drop database日志语句,或者使用stop-position来限定binlog结束位置,下面使用stop-position参数限定:

bash 复制代码
mysqlbinlog -uroot -p --start-position=154
--stop-position=787 /var/lib/mysql/mysql-bin.000002>000003binlog.sql

执行增量的binlog恢复

bash 复制代码
source 000003binlog.sql;

# 查询数据

select * from t2;

select count(*) from t2;

至此,就已经完成数据的恢复。这里主要结合了全量备份和binlog日志方式进行。

相关推荐
计算机安禾5 小时前
【数据库系统原理】第19篇:计算机存储层次结构与数据库文件的物理组织
数据库·oracle
JAVA面经实录9176 小时前
操作系统面试题
java·服务器·数据库·计算机网络·面试
摇滚侠6 小时前
mariadb-libs 被 mysql-community-libs-5.7.28-1.el7.x86_64 取代
数据库·mysql·mariadb
DIY源码阁7 小时前
JavaSwing饮品管理系统 - MySQL版
java·数据库·mysql·eclipse
专注搞钱7 小时前
GPT-4o写设备Recipe:从3小时到10分钟
数据库·人工智能·gpt·半导体
东风破1378 小时前
达梦数据库实战:备份恢复与数据迁移全攻略(实例初始化、服务注册、路径迁移)
数据库·chrome
SelectDB技术团队8 小时前
2026 SelectDB AI 产品发布会:Agent Native 数据基础设施能力全景发布
数据库·人工智能·agent·apache doris·selectdb
爱吃羊的老虎8 小时前
【数据库】模块一:数据库基础与关系代数
数据库
dishugj9 小时前
iSCSI + Multipath + ASM:Oracle RAC 共享存储技术链详解
数据库·oracle
yoothey9 小时前
MySQL事务机制解析 - 面试高分知识点
数据库·mysql·面试