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

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

话不多说,进入正题

一、导入数据

我的源数据:baodian_2018-09-25_.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

最新文章

  1. Vsftp精解之安装配置及原理(一)
  2. C# Socket系列二 简单的创建 socket 通信
  3. 6.nodejs权威指南--进程
  4. openssl AES加密以及padding
  5. Linux 命令 - tail: 打印文件的结尾部分
  6. order by跟group by 跟having----------------sum() 求和   avg()求平均   count() 求个数--------------like
  7. appsettings.json
  8. myeclipse 扩展内存大小
  9. Ext JS添加子组件的误区
  10. XAMPP重置MySQL密码
  11. hadoop_随笔二_参数
  12. Oracle 10G 安装文档
  13. java基础题整理(1)
  14. Codeforces Round #375 (Div. 2) E. One-Way Reform 欧拉路径
  15. C语言 · 算年龄
  16. 21-js 实现评论时间格式转化
  17. UVa 10298 - Power Strings
  18. GreenOpenPaint的实现(六)图片的保存和打开
  19. “全栈2019”Java第三章:安装开发工具IntelliJ IDEA
  20. Gin实战:Gin+Mysql简单的Restful风格的API(二)

热门文章

  1. ImportError: No module named 'httplib'
  2. this调用属性
  3. 6-5 Haar特征2
  4. 一个NodeJS写的基于MVC的服务器
  5. Javascript中的回调函数和匿名函数的回调示例介绍
  6. 关于 <meta name="viewport" content="width=device-width, initial-scale=1.0">的解释
  7. dwr学习 之 一、dwr+spring的简单集成
  8. SpringSercurity基础
  9. 7天学完Java基础之7/7
  10. Redis生成主键ID