怎么通过日志文件恢复MySQL数据

怎么通过日志文件恢复MySQL数据

这篇文章主要介绍“怎么通过日志文件恢复MySQL数据”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“怎么通过日志文件恢复MySQL数据”文章能帮助大家解决问题。

    1、找到最新的 binlog 文件

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

    怎么通过日志文件恢复MySQL数据

    mysql>showmasterstatus;+------------------+-----------+|Log_name|File_size|+------------------+-----------+|binlog.000001|967||binlog.000002|965|+------------------+-----------+

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

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

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

    2.1、使用时间范围

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

    #at131708213#21061011:27:01serverid1end_log_pos131708311CRC320x0fc755e2Table_map:`loongwind_base`.`xxxx`mappedtonumber139#at131708311#21061011:27:01serverid1end_log_pos131708411CRC320xa91616b9Write_rows:tableid139flags:STMT_END_FBINLOG'BffBYBMBAAAAYgAAAJe12QcAAIsAAAAAAAEADmR4bWhfYmFzZV9oenN5ABpkeF9zeV9hc3NldHNfZXh0ZW5kc19jb3B5MQAICAgIDwgSCBIEAAgAAPgBAQACA/z/AOJVxw8=BffBYB4BAAAAZAAAAPu12QcAAIsAAAAAAAMAAgAI/wDRAwAAm1M8AUIAAADRUjwBCgAAAFYL5gAMAOWFrOWuieacuuWFs7EBAADbwZkAmama6E+xAQAA28GZAJmpmuhPuRYWqQ=='/*!*/;

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

    2.2、使用 position 范围

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

    mysql-uroot-p'password'-e"showbinlogeventsin'binlog.000002'"|grep-i'DROPTABLE'

    执行结果如下:

    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-0709:00:00"--stop-datetime="2021-06-1016:37:58"binlog.000005|mysql-uroot-p'password'-s-N-f-Dloongwind_base

    其中 dxmh_base_hzsy 是数据库名称

    3.2 通过 position 恢复

    mysqlbinlog--start-position=1178--stop-position=2751-ddxmh-sybinlog.000002|mysql-uroot-p'password'-s-N-f-Dloongwind_baseloongwind_base为数据库名称

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

    关于“怎么通过日志文件恢复MySQL数据”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注恰卡编程网行业资讯频道,小编每天都会为大家更新不同的知识点。

    发布于 2022-02-07 23:15:03
    收藏
    分享
    海报
    0 条评论
    39
    上一篇:shell中怎么根据进程查找指定容器 下一篇:JavaScript怎么找出数组中的重复或非重复元素
    目录

      0 条评论

      本站已关闭游客评论,请登录或者注册后再评论吧~

      忘记密码?

      图形验证码