MySQL 小技巧:恢复误删除的表

news2025/1/11 6:06:02

案例说明

每天 2:30 做完全备份,早上 10:00 误删除 了表 students,10:10 才发现故障

现需要将数据库还原到 10:10 的状态,且恢复被删除的 students 表。

思路分析

  1. 停止数据库服务
  2. 将数据 还原到 2:30 的完全备份状态
  3. 再通过二进制日志还原
    1. 默认:二进制日志记录到了 10:10 你停止数据库的时间
    2. 因此:此二进制日志文件中记录着 10:00 删表的动作
    3. 所以:我们可以 将该二进制日志文件中的删表动作去除
  4. 然后基于 该去除了删除操作的二进制日志内容 将数据还原( 此期间需要关闭二进制日志记录功能 )

实际操作

前置操作

  1. 验证数据库的二进制日志功能是否开启( 且二进制日志文件存放在不同目录 )
  2. 二进制日志类型( ROW 行类型 )
0) "前置条件" ( 开启二进制日志功能 )
## 并将二进制日志文件与数据库文件分开存放
1. 创建二进制日志文件的存放目录
mkdir /mysql/data/logbin -pv
chown -R mysql:mysql /mysql/data/logbin/

2. 定义二进制日志文件路径 ( 服务器选项: log-bin )
vim /etc/my.cnf
vim /etc/my.cnf.d/mysql-server.cnf      # MySQL 8.0
[mysqld]
log_bin                                 # 开启二进制日志功能 ( 必须 )
log-bin=/mysql/data/logbin/mysql-bin    # 定义二进制日志文件路径

3. 重启 mariadb 服务
setenforce 0         # 关闭 SELinux ( 重要 )
systemctl restart mariadb.service
# 如重启报错 ( 可以尝试查看日志 tail -f /var/log/mysql/mysqld.log )
# 将报错信息发送至 ChatGPT 为你提供解决思路

4. 验证
ll /mysql/data/logbin
cat /mysql/data/logbin/mysql-bin.index ( 该文件记录当前已有的二进制日志文件列表 )

5. 验证
select @@sql_log_bin;
select @@log_bin;
select @@binlog_format;    # 查看二进制日志类型

模拟 误删数据

  1. 模拟 2:30 的完全备份
  2. 模拟 2:30 -10:00 之间的数据更新
  3. 模拟 10:00 误删除了一个重要的表
  4. 模拟 10:00 后其他表数据还在更新
  5. 模拟 10:10 发现异常

模拟 还原过程

  1. 停止数据库服务
  2. 基于 mysqlbinlog 导出二进制日志文件内容
  3. 将二进制日志文件中的删表操作去除!
  4. 准备还原数据库
    1. 启用数据库服务
    2. 登录数据库,临时关闭二进制日志功能
    3. 先还原完全备份数据
    4. 再还原二进制日志文件数据
    5. 开启二进制日志功能
  5. 验证数据库内容
// 模拟 2:30 的完全备份
// -F 选项会刷新使用一个新的二进制日志文件
[root@centos8 ~] mysqldump -uroot -p -A -F --single-transaction --master-data=2 > /backup/allbackup_`date +%F_%T`.sql

[root@centos8 ~] ll /backup/

-rw-r--r--. 1 root root 1235591 Feb  3 13:31 allbackup_2024-02-03_13:31:12.sql

// 完全备份后的数据更新 ( 模拟 2:30 -10:00 之间的数据更新 )
use hellodb;
insert students (stuid,name,age,gender) values('50','rose',20,'f');
insert students (stuid,name,age,gender) values('60','bob',20,'m');

// 模拟 10:00 误删除了一个重要的表
drop table students;

// 后续其它表继续更新  ( 模拟 10:00 后其他表数据还在更新 )
use hellodb1;
insert teachers (tid,name,age,gender) values('50','wangj',20,'f');
insert teachers (tid,name,age,gender) values('60','wangjun',20,'m');

MariaDB [hellodb1]> select * from teachers;
+-----+---------------+-----+--------+
| TID | Name          | Age | Gender |
+-----+---------------+-----+--------+
|   1 | Song Jiang    |  45 | M      |
|   2 | Zhang Sanfeng |  94 | M      |
|   3 | Miejue Shitai |  77 | F      |
|   4 | Lin Chaoying  |  93 | F      |
|  50 | wangj         |  20 | f      |
|  60 | wangjun       |  20 | m      |
+-----+---------------+-----+--------+
6 rows in set (0.00 sec)

// 10:10 发现表删除 ( 模拟 10:10 发现异常 )
// 先停止数据库
systemctl stop mysqld

// 从完全备份中, 找到二进制位置 ( 找到 2:30 - 10:10 使用的二进制日志文件名称 )
[root@centos8 ~] grep '\-\- CHANGE MASTER TO' /backup/allbackup_2024-02-03_13\:31\:12.sql
-- CHANGE MASTER TO MASTER_LOG_FILE='mysql-bin.000003', MASTER_LOG_POS=156;    # 得到的信息

// "基于 mysqlbinlog 导出二进制日志文件内容"
[root@centos8 ~] mysqlbinlog --start-position=156 /mysql/data/logbin/mysql-bin.000003 > /backup/inc.sql

// 找到误删除的语句, 从备份文件中删除此语句
// 也就是将二进制日志文件中的删表操作去除!
[root@centos8 ~] vim /backup/inc.sql
# DROP TABLE `student_info` /* generated by server */

// 注: 如果文件过大, 可以使用 sed 实现    ( "重要" )
[root@centos8 ~] sed -i.bak '/^DROP TABLE/d' /backup/inc.sql

// 利用完全备份和修改过的二进制日志进行还原操作
[root@centos8 ~] systemctl start mysqld      # 启用数据库服务
[root@centos8 ~] mysql -uroot -p
MariaDB [hellodb]> set sql_log_bin=0;        # 临时关闭二进制日志功能
MariaDB [hellodb]> source /backup/allbackup_2024-02-03_13:31:12.sql;
MariaDB [hellodb]> source /backup/inc.sql;
MariaDB [hellodb]> set sql_log_bin=1;        # 开启二进制日志功能

// "验证数据库"
mysql -e 'show databases';
mysql -e 'select * from hellodb.students;'
mysql -e 'select * from hellodb1.teachers;'

基于如上案例,我们可以得知开启二进制日志功能的重要性以及每天做全量备份的重要性。

注意:二进制日志文件不要与数据库文件存放同一个目录。全量备份的文件也应该不存放于本机,而存放在其他主机。异机器备份。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1429901.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

羊大师:冬季出行,心血管病患者应做好哪些准备?

羊大师:冬季出行,心血管病患者应做好哪些准备? 冬季将至,气温骤降,寒冷的天气不仅让人感到不适,对于患有心血管病的人来说,更是需要格外注意。在这个寒冷的季节里,心血管病患者需要…

今日arXiv最热NLP大模型论文:IBM研究院提出Genie方法,自动生成高质量数据集

数据是大模型的基石。但传统的数据集创建方法通常依赖人工,耗时耗力成本高,另外数据集的来源复杂,噪声大,比如新闻媒体稿或者社交媒体,数据质量难以保证。为此,IBM研究院了一种名为Genie的新方法&#xff0…

Android搭建python环境

通过wifi连接adb: 首先下载无线abd工具: https://www.downkuai.com/android/170494.html 运行效果图: 然后开启后根据自身ip即可连接: adb connect ip:5555 安装busybox: 首先执行如下命令查看手机架构: adb sh…

【新书推荐】5.1节 16位汇编语言学习环境

第五章 16位汇编学习环境 16位汇编语言的学习环境是建立在8086计算机的基础上的,我将借助于DosBox虚拟机来实现16位汇编语言学习环境的搭建。 5.1节 16位汇编语言学习环境 本节内容:16位汇编学习环境的搭建。 ■汇编语言程序设计编程调试过程&#xff1…

手机云控制发电机组 有网络随时随地操控监控运行

GenCloudTM 发电机组云控系统简介 Ver2.0 目录 公司简介…… …………………………… ………………………………………………1概 述…… …………………………… ………………………………………………1主要功能及特点………… …………… ………… ………………………………

JAVA基础 队列

排队取奶茶 时间限制:1.000S 空间限制:128MB 题目描述 假设有一家奶茶店,现在有一些人在排队等待取奶茶,同时也有人在取奶茶。 请你设计一个程序模拟这种情况下的奶茶队列管理。 假设每个人取奶茶的时间非常短,可…

【算法与数据结构】718、1143、LeetCode最长重复子数组 最长公共子序列

文章目录 一、718、最长重复子数组二、1143、最长公共子序列三、完整代码 所有的LeetCode题解索引,可以看这篇文章——【算法和数据结构】LeetCode题解。 一、718、最长重复子数组 思路分析: 第一步,动态数组的含义。 d p [ i ] [ j ] dp[i]…

《PCI Express体系结构导读》随记 —— 第II篇 第4章 PCIe总线概述(5)

接前一篇文章:《PCI Express体系结构导读》随记 —— 第II篇 第4章 PCIe总线概述(4) 4.1.2 PCIe总线使用的信号 PCIe设备使用两种电源信号供电,分别是Vcc与Vaux,其额定电压为3.3V。其中Vcc为主电源,PCIe设备…

【前端web入门第三天】02 CSS字体和文本

文章目录: 1.字体 1.1 字体大小 1.2 字体粗细 1.3 字体样式 1.4 行高 1.5 字体族 1.6 font 复合属性 2. 文本 2.1 文本缩进2.2 文本对齐方式2.3 文本修饰线2.4 color文字颜色 1.字体 1.1 字体大小 属性名: font-size属性值:文字尺寸,PC端网页最常用的单位px …

java通过反射获取表名以及表的全部字段

目录 前言获取表名获取表字段获取表字段并且以object类返回 前言 市面上找了一下能够获取表名和表字段的方法,最后结果不是很理想,于是自己写一套 获取表名 //获取表名public static String getTableName(Object object) {Field[] fields object.getC…

python_蓝桥杯刷题记录_笔记_全AC代码_入门2

前言 现在正式进入蓝桥杯的刷题啦,用python来做算法题,因为我之前其实都是用C来做题的,但是今年的话我打算换python来试试,很明显因为也才这学期接触python 加上之前C做题也比较菜,所以我打算用python重新来做题&#…

Navicat的使用教程,操作详解

这篇文章主要针对mysql数据库。 在使用Navicat之前,首先要确保你在本地已经安装好了,mysql数据库,安装教程可以参考我的另一篇博文 在windows平台上mysql的安装教程-CSDN博客 1.Navicat连接你的数据库 连接名,随便写&#xff0c…

TCP/IP详细介绍以及TCP/IP寻址

目录 ​编辑 1. TCP/IP 介绍 2. 计算机通信协议(Computer Communication Protocol) 3. 什么是 TCP/IP? 4. 在 TCP/IP 内部 5. TCP 使用固定的连接 6. IP 是无连接的 7. IP 路由器 8. TCP/IP 9. TCP/IP 寻址 10. IP地址 …

Linux下新建用户

新建用户 sudo adduser -m username添加密码 sudo passwd username设置权限 sudo vi /etc/sudoers在user privilege这一行,仿照root,另起一行,添加上 设置命令解释器 sudo vi /etc/passwd找到新建用户名,将sh改为bash vi中…

在Linux中如何理解页表和进程地址

1、进程地址是进程读取资源的窗口 2、页表决定了进程真实拥有的资源情况 3、合理的对进程地址空间页表进行资源划分,就可以对进程的资源进行分类 这个过程应该如何去理解呢请看下面的图 我们知道程序被加载到进程中,会产生相应的PCB,并且…

react 之 useCallback

简单讲述下useCallback的使用方法,useCallback也是用来缓存的,只不过是用于做函数缓存 // useCallbackimport { memo, useCallback, useState } from "react"const Input memo(function Input ({ onChange }) {console.log(子组件重新渲染了…

python_蓝桥杯刷题记录_笔记_全AC代码_入门4

题单目录 1.P1914 小书童——凯撒密码 2.P1028 [NOIP2001 普及组] 数的计算 3.P1036 [NOIP2002 普及组] 选数 4.P1149 [NOIP2008 提高组] 火柴棒等式 5.P1217 [USACO1.5] 回文质数 Prime Palindromes 6.P1478 陶陶摘苹果(升级版) 7.P1618 三连击&…

第二代视频换脸工具facefusion

GitHub - facefusion/facefusion: Next generation face swapper and enhancer官方地址 1.环境安装 Windows - FaceFusion Windows Python winget install -e --id Python.Python.3.10 PIP python -m ensurepip --upgrade GIT winget install -e --id Git.Git

【Go语言成长之路】安装Go

文章目录 安装Go一、下载Go语言安装包二、删除以前安装的Go版本三、添加/usr/local/go/bin到环境变量内四、确认安装成功 安装Go Note: 这里只演示安装Linux版本的Go,若为其它版本,请按照官网的安装教程进行安装即可。 一、下载Go语言安装包 ​ 在浏览…

1Panel应用推荐:青龙定时任务管理平台

1Panel(github.com/1Panel-dev/1Panel)是一款现代化、开源的Linux服务器运维管理面板,它致力于通过开源的方式,帮助用户简化建站与运维管理流程。为了方便广大用户快捷安装部署相关软件应用,1Panel特别开通应用商店&am…