教你如何通过日志文件恢复MySQL数据

作者:LoongWind 时间:2024-01-29 07:11:07 

前言

本文将讲述怎么通过 MySql 的日志 binlog 文件进行数据恢复。

通过已备份数据 加上 binlog 文件恢复上次备份到删除之间的数据

1、找到最新的 binlog 文件

进入 mysql 命令行执行如下命令

mysql> show master status;
+------------------+-----------+
| Log_name         | File_size |
+------------------+-----------+
| binlog.000001 |       967 |
| binlog.000002 |       965 |
+------------------+-----------+

一般最新的编号大,上面最新的就是 binlog.000002

2、找到我们想恢复数据在日志文件里的开始结束位置

这里有两种方式来确定开始位置和结束位置,一种是使用时间作为开始结束,一种是使用日志的 position 作为开始结束位置

2.1、使用时间范围

通过 mysqlbinlog mysql-bin.000002 命令查看日志内容,然后找到删除的时间点:

# at 131708213
#210610 11:27:01 server id 1  end_log_pos 131708311 CRC32 0x0fc755e2     Table_map: `loongwind_base`.`xxxx` mapped to number 139
# at 131708311
#210610 11:27:01 server id 1  end_log_pos 131708411 CRC32 0xa91616b9     Write_rows: table id 139 flags: STMT_END_F

BINLOG '
BffBYBMBAAAAYgAAAJe12QcAAIsAAAAAAAEADmR4bWhfYmFzZV9oenN5ABpkeF9zeV9hc3NldHNf
ZXh0ZW5kc19jb3B5MQAICAgIDwgSCBIEAAgAAPgBAQACA/z/AOJVxw8=
BffBYB4BAAAAZAAAAPu12QcAAIsAAAAAAAMAAgAI/wDRAwAAm1M8AUIAAADRUjwBCgAAAFYL5gAM
AOWFrOWuieacuuWFs7EBAADbwZkAmama6E+xAQAA28GZAJmpmuhPuRYWqQ==
'/*!*/;

然后确定上次备份的时间点,如果通过日志找不到上次备份的时间点可以填一个你记忆中确定小于上次备份的时间点

2.2、使用 position 范围

使用如下命令查看日志 event 的 position

mysql -uroot -p'password' -e "show binlog events in 'binlog.000002'"|grep -i 'DROP TABLE'

执行结果如下:

binlog.000002    820474948    Query    1    820475111    use `loongwind_base`; DROP TABLE IF EXISTS `undo_log` /* generated by server */ /* xid=11790691 */

即删除的 position 为 820474948

还是通过上述命令,替换关键字查找到上次备份的 position 点

3、恢复

3.1 通过时间恢复

mysqlbinlog --no-defaults --database=loongwind_base --start-datetime="2021-06-07 09:00:00" --stop-datetime="2021-06-10 16:37:58" binlog.000005 | mysql -uroot -p'password' -s -N -f -D loongwind_base

其中 dxmh_base_hzsy 是数据库名称

3.2 通过 position 恢复

mysqlbinlog  --start-position=1178  --stop-position=2751 -d dxmh-sy binlog.000002|mysql -uroot -p'password' -s -N -f -D loongwind_base
loongwind_base 为数据库名称

如果实在找不到开始时间或者开始 position 也可以不写 --start-datetime 或 --start-position ,这样就是用这个日志文件的开始一直恢复到结束,为了防止与已有数据的冲突,需要加上 -f 即 force 跳过错误继续往下执行。

来源:https://www.loongwind.com/archives/370.html

标签:mysql,日志,恢复
0
投稿

猜你喜欢

  • Sql2005启用和关闭xp_cmdshell功能

    2008-09-29 15:37:00
  • HTML4标签的默认样式列表

    2007-09-28 22:00:00
  • 使用python3调用wxpy模块监控linux日志并定时发送消息给群组或好友

    2022-05-12 03:35:29
  • python实现处理mysql结果输出方式

    2024-01-28 03:30:42
  • 简单介绍Ruby中的CGI编程

    2022-09-07 21:38:14
  • javascript实现数独解法

    2023-10-17 17:18:28
  • ExtJS 开发总结

    2009-04-28 13:05:00
  • vue中如何引入html静态页面

    2023-07-02 17:03:34
  • 详解Python:面向对象编程

    2023-10-26 16:17:53
  • opencv+pyQt5实现图片阈值编辑器/寻色块阈值利器

    2023-09-10 11:22:34
  • PHP addAttribute()函数讲解

    2023-06-06 09:03:45
  • Bootstrap Multiselect 常用组件实现代码

    2024-05-21 10:14:36
  • Python xlwt工具使用详解,生成excel栏位宽度可自适应内容长度

    2024-01-03 20:20:20
  • 基于Python编写简易文字语音转换器

    2023-12-28 19:24:54
  • PHP json格式和js json格式 js跨域调用实现代码

    2023-11-22 05:20:18
  • python绘制直方图的方法

    2021-08-20 14:59:32
  • 使用Python绘制空气质量日历图

    2023-06-20 12:19:21
  • Python中pip更新和三方插件安装说明

    2021-02-07 13:22:39
  • 面向对象设计过程中必须遵守的相关准则

    2009-01-08 15:52:00
  • vue axios二次封装的详细解析

    2024-01-18 01:43:44
  • asp之家 网络编程 m.aspxhome.com