mysqlbin log日志回放进行操作步骤

以下操作均是在windows系统中进行

1、首先查看当前的mysql是否开启binlog日志:

 show variables like 'log_%'; 

(如果查看到已经开启binlog日志直接进行第三步操作)

2、开启binlog日志

mysql安装主目录下,找到my.ini 文件,做以下新增,
#binlog文件地址
log-bin=D:/shanly/mysql/mysql-5.7.34-win32/data/binlog

server-id=1
#加入此参数才能记录到insert语句
binlog_format=MIXED

3、对日志进行输出

flush logs

这时会第二步设置的binlog输出目录中输出binlog.0001类似的文件

4、进行binlog日志操作

进入到mysql安装目录下bin目录

1、cd D:\shanly\mysql\mysql-5.7.34-win32\bin
2、在文件夹地址栏中输入cmd进入到命令模式,

mysqlbinlog binlog.000001
/*!50530 SET @@SESSION.PSEUDO_SLAVE_MODE=1*/;
/*!50003 SET @OLD_COMPLETION_TYPE=@@COMPLETION_TYPE,COMPLETION_TYPE=0*/;
DELIMITER /*!*/;
mysqlbinlog: File 'binlog.000001' not found (Errcode: 2 - No such file or directory)
SET @@SESSION.GTID_NEXT= 'AUTOMATIC' /* added by mysqlbinlog */ /*!*/;
DELIMITER ;
# End of log file
/*!50003 SET COMPLETION_TYPE=@OLD_COMPLETION_TYPE*/;
/*!50530 SET @@SESSION.PSEUDO_SLAVE_MODE=0*/;

5、从binlog日志恢复数据

将以上操作mysql的binlog日志进行提取,并做如下操作

a、恢复命令的语法格式:

mysqlbinlog mysql-bin.0000xx | mysql -u用户名 -p密码 数据库名

b、常用参数选项解释:

–start-position=875 起始pos点
 --stop-position=954 结束pos点
 --start-datetime=“2016-9-25 22:01:08” 起始时间点
 --stop-datetime=“2019-9-25 22:09:46” 结束时间点
 --database=ops指定只恢复ops数据库(一台主机上往往有多个数据库,只限本地log日志)

c、不常用选项:

-u --user=name 连接到远程主机的用户名
  -p --password[=name]连接到远程主机的密码
  -h --host=name 从远程主机上获取binlog日志
  --read-from-remote-server从某个Mysql服务器上读取binlog日志

d、小结:实际是将读出的binlog日志内容,通过管道符传递给myslq命令。这些命令,文件尽量写成绝对路径;
e、完全恢复(需要手动vim编辑mysql-bin.000003,将那条drop语句剔除掉)(此方法测试未通过)

/application/mysql3306/bin/mysqlbinlog /application/mysql3306/mysql_data/mysql-bin.000004 | /application/mysql3307/bin/mysql -uroot -S /application/mysql3307/logs/mysql.sock -p123456 -v ops

f、指定pos结束点恢复(部分恢复):
/application/mysql3306/bin/mysqlbinlog --stop-position=3064 --database=ops /application/mysql3306/mysql_data/mysql-bin.000002 | /application/mysql3307/bin/mysql -uroot -S /application/mysql3307/logs/mysql.sock -p123456 -v(因为加了–database=ops因此不会恢复二进制日志中关于ops1库的相应操作,若也需要恢复ops1库的相应操作,则再加上–database=ops1即可)

PS:以上第四步操作转自(https://blog.csdn.net/sinat_32430939/article/details/121533785)

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

山不在高_有仙则灵

你的奖励是我的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值