mysql利用binlog恢复数据

需求:需要给开发提供一个2018年9月30号的数据,按照我们公司正常备份策略来说,直接找到对应时间的备份数据,解压导入即可,恰好这个时间节点的数据没有,只备份到2018年9月25号的,糟糕了吧

          咋办呢,咱们利用binlog日志来恢复吧,如果二进制日志都没有,那还恢复啥呢,运维咋当滴

          话不多说,进入正题

一、导入数据

我的源数据:baodian_2018-09-25_329010659.tar.bz2               #这一串数字是pos节点位置,等下利用二进制恢复的时候需要用到,时间:9月 25 01:08

随便在哪个mysql数据库解压导入即可,根据自己的需求就行

二、找到对应的binlog

知道的时间节点:

1.开始pos位置:329010659

2.结束时间:2018-10-01 00:00:00

# 二进制日志分析
2018-09-22 12:34:23.459540935 2018-09-29 15:54:20.554318725 mysql-bin.000163
2018-09-29 15:54:20.554318725 2018-10-04 00:09:50.238484899 mysql-bin.000164

 

三、数据恢复

利用binlog恢复,一条命令搞定

/usr/local/mysql/bin/mysqlbinlog  --start-position=329010659  --stop-datetime='2018-10-01 00:00:00'  --database=baodian     --set-charset=utf8      mysql-bin.000163      mysql-bin.000164    |mysql -h127.0.0.1 -P3036 -uroot -p123456 baodian

温馨提示:

1.mysqlbinlog分析多个文件的时候,不能分开写,否则导入的时候会报语法错误,如图

2.尽量加上字符集编码参数,否则中文是乱码

   我的是: --set-charset=utf8 

3. mysqlbinlog分析分时候,不要加这个参数,--base64-output=decode-rows,否则数据导不进去    #当然是根据我的环境来说的

其实我觉得一般是可以的,可能是我my.cnf里面设置了格式为row

4.如果导数据的时候,出现如下两种报错信息

   1)ERROR 1609 (HY000): The BINLOG statement of type `Table_map` was not preceded by a format description BINLOG statement.    #直接在数据库source的时候

   2) ERROR 2006 (HY000) at line xx: MySQL server has gone away  #出现这个原因有很多种,其他原因的解决办法参考:https://www.cnblogs.com/fnlingnzb-learner/p/5984795.html

   这里的原因是,sql操作时间过长,传送的数据太大,可以设置max_allowed_packed来避免

  解决:在my.cnf里面添加一行参数

  max_allowed_packed=16M     #如果不行将16M再加大

mysqlbinlog其他用法,参考:

https://www.cnblogs.com/kevingrace/p/5907254.html

原文地址:https://www.cnblogs.com/tianfen/p/9947837.html