mysql5.7.44误删除数据后,使用binlog日志恢复

系统环境

bash 复制代码
#系统版本
# cat /etc/redhat-release
CentOS Linux release 7.9.2009 (Core)
#数据库版本
# mysql -V
mysql  Ver 14.14 Distrib 5.7.44, for Linux (x86_64) using  EditLine wrapper

恢复前提

本文仅适合mysql数据库已经开启binlog日志的情况。
查看binlog是否开启

bash 复制代码
mysql> show variables like '%log_bin%';
+---------------------------------+--------------------------------+
| Variable_name                   | Value                          |
+---------------------------------+--------------------------------+
| log_bin                         | ON                             |
| log_bin_basename                | /var/lib/mysql/mysql-bin       |
| log_bin_index                   | /var/lib/mysql/mysql-bin.index |
| log_bin_trust_function_creators | OFF                            |
| log_bin_use_v1_row_events       | OFF                            |
| sql_log_bin                     | ON                             |
+---------------------------------+--------------------------------+
# ON 表示成功开启

查看binlog路径

bash 复制代码
mysql> show variables like '%datadir%';
+---------------+-----------------+
| Variable_name | Value           |
+---------------+-----------------+
| datadir       | /var/lib/mysql/ |
+---------------+-----------------+
1 row in set (0.00 sec)

恢复操作

模拟删除数据

bash 复制代码
mysql> delete from task_fail where id = 20;
Query OK, 1 row affected (0.38 sec)

mysql> delete from task_fail where id = 21;
Query OK, 1 row affected (0.04 sec)

mysql> delete from task_fail where id = 22;
Query OK, 1 row affected (0.06 sec)

mysql> delete from task_fail where id = 23;
Query OK, 1 row affected (0.07 sec)

mysql> select id from task_fail order by id asc;
+----+
| id |
+----+
|  1 |
|  2 |
|  3 |
|  4 |
|  5 |
|  6 |
|  7 |
|  8 |
|  9 |
| 10 |
| 11 |
| 12 |
| 13 |
| 14 |
| 15 |
| 16 |
| 17 |
| 18 |
| 19 |
| 24 |
| 25 |
| 26 |

将删除时间段binlog翻译为sql

bash 复制代码
# mysqlbinlog --base64-output=decode-rows -v --database=airflow --start-datetime="2024-05-07 15:30:00" --stop-datetime="2024-05-07 15:50:00" "/var/lib/mysql/mysql-bin.000001" > delete.sql

将上述的sql文件delete修改为insert的sql

bash 复制代码
# cat delete.sql | sed -n '/###/p' | sed 's/### //g;s/\/\*.*/,/g;s/DELETE FROM/;INSERT INTO/g;s/WHERE/SELECT/g;' |sed -r 's/(@17.*),/\1;/g' | sed 's/@1=//g'| sed 's/@[1-9]=/,/g' | sed 's/@[1-9][0-9]=/,/g' > insert.sql

执行insert sql,恢复误删除数据

bash 复制代码
mysql> source /root/insert.sql
ERROR:
No query specified

Query OK, 1 row affected (0.04 sec)
Records: 1  Duplicates: 0  Warnings: 0

Query OK, 1 row affected (0.03 sec)
Records: 1  Duplicates: 0  Warnings: 0

Query OK, 1 row affected (0.03 sec)
Records: 1  Duplicates: 0  Warnings: 0

Query OK, 1 row affected (0.04 sec)
Records: 1  Duplicates: 0  Warnings: 0

验收数据恢复情况

bash 复制代码
mysql> select id from task_fail order by id asc;
+----+
| id |
+----+
|  1 |
|  2 |
|  3 |
|  4 |
|  5 |
|  6 |
|  7 |
|  8 |
|  9 |
| 10 |
| 11 |
| 12 |
| 13 |
| 14 |
| 15 |
| 16 |
| 17 |
| 18 |
| 19 |
| 20 |
| 21 |
| 22 |
| 23 |
| 24 |
| 25 |

id 20 21 22 23 的数据已经恢复。

相关推荐
鸽芷咕34 分钟前
DrissionPage 成 CANN 仓库爆款自动化工具:背后原因何在?
运维·python·自动化·cann
池央43 分钟前
CANN 算子生态的深度演进:稀疏计算支持与 PyPTO 范式的抽象层级
运维·人工智能·信号处理
OJAC1111 小时前
当所有人都在说“运维稳了”,近屿智能看到了另一种可能
运维
chian-ocean1 小时前
CANN 生态进阶:利用 `profiling-tools` 优化模型性能
数据库·mysql
人鱼传说1 小时前
docker desktop是一个好东西
运维·docker·容器
阿梦Anmory2 小时前
Ubuntu配置代理最详细教程
linux·运维·ubuntu
呉師傅2 小时前
【使用技巧】Adobe Photoshop 2024调整缩放与布局125%后出现点菜单项漂移问题的简单处理
运维·服务器·windows·adobe·电脑·photoshop
heartbeat..2 小时前
JVM 性能调优流程实战:从开发规范到生产应急排查
java·运维·jvm·性能优化·设计规范
那个村的李富贵2 小时前
解锁CANN仓库核心能力:50行代码搭建国产化AIGC图片风格迁移神器
mysql·信息可视化·aigc·cann
小Tomkk2 小时前
数据库 变更和版本控制管理工具 --Bytebase 安装部署(linux 安装篇)
linux·运维·数据库·ci/cd·bytebase