【这是一猿小讲的第 72 篇原创分享】

今天一位跨界老码农不知咋回事,兴奋过了头,一不小心把数据库给删掉啦,然后问我咋恢复,然后我告诉他基于 binlog 可以恢复,谁成想没有开启 binlog,最后只能躲在角落里伤心。

爱情 36 技系列,好久没更新啦,真是苦了追逐爱情系列的那些朋友们。

好了,请忘记上面的一切,因为我们的爱情故事系列又要更新啦。

自从 Java 那小子喜获 Python 菇凉的芳心之后,两人就迈入了柴米油盐酱醋茶的生活,但是锅碗瓢盆难免磕磕碰碰,生活中吵吵闹闹甚是正常。

不过每次小吵小闹,Python 菇凉都会忍不住想删除存储在 MySQL 上的旅途记忆(不是想删库,就是想跑路)。但是老话说的好:天上月亮圆圆的,小两口吵架总是闹着玩的,况且小两口没有隔夜的仇,所以每次花好月圆之时,Java 那小子总会凭自己精湛的技艺把 Python 菇凉放在 MySQL 上的记忆给恢复如初。

另外 Java 那小子为了帮助其他家庭能够快速重建美好记忆,考虑到家庭稳固,特意把秘诀分享给大家,希望大家拿去使用,估计会屡试不爽。

秘诀一:记录日志,让你有迹可查


第一步:确认 binlog 日志是否处于开启状态 ?

show variables like 'log_%';

第二步:开启 MySQL binlog 日志

首先找到 my.cnf 文件。

mysql --help | grep 'Default options' -A 1

可能会有一堆的 my.cnf,加载的优先级顺序如下,别傻傻分不清。

不过也有可能 my.cnf 文件都是空空如也,别以为是见鬼啦,空空如也,就根据需要添加自己的配置就行。

vim /etc/my.cnf

#添加
[mysqld]
#设置日志格式
binlog_format=mixed
#日志文件的名字及存储路径(咱们这次配置的路径为默认)
log-bin=mysql-bin
#表示单个节点的id,用来在集群中区别服务器
server-id=1

第三步:重启 MySQL

不同的系统,重启指令也不同,我是 Mac 系统,操作如下

sudo /usr/local/mysql/support-files/mysql.server restart

第四步:确认 binlog 日志是否真开启啦?

show variables like 'log_%';

第五步: 熟练使用命令。

查看 binlog 所有日志列表:show master logs;

查看最新一个 binlog 日志的信息:show master status;

秘诀二:望闻问切,辨证施药


病理一:Python 菇凉一怒之下,删除了去东京的旅途记忆。

望闻问切:查看 mysql-bin.000003 日志文件中记录的 Python 菇凉的操作,找到上一步的状态位置。

show binlog events in 'mysql-bin.000003';

确诊:从 binlog 的事件中可以看断出执行 Python 菇凉执行 delete from memories 语句前的 position 节点为 1240,所以恢复开始的 pos 节点为 962,停止的 pos 节点为 1240 。

施药:采用 mysqlbinlog 完成恢复,治疗效果杠杠滴,去东京的旅途记忆又回来啦。

mysqlbinlog /usr/local/mysql/data/mysql-bin.000003 --start-position 962 --stop-position 1240 | mysql -u root -p travel

病理二:Python 菇凉一怒之下,删除了所有的旅途记忆。

望闻问切:查看 mysql-bin.000003 日志文件中记录的 Python 菇凉的操作,找到上一步的状态位置。

show binlog events in 'mysql-bin.000003';

确诊:从 binlog 的事件中可以看断出执行 Python 菇凉执行 drop table memories 语句前的 position 节点为 1873,所以恢复开始的 pos 节点为 154,停止的 pos 节点为 1873 。

施药:采用 mysqlbinlog 完成恢复,治疗效果杠杠滴,神奇的是所有的旅途记忆都回来啦。

mysqlbinlog /usr/local/mysql/data/mysql-bin.000003 --start-position 154 --stop-position 1873 | mysql -u root -p travel

病理三:Python 菇凉一怒之下,把数据库都删掉了。

望闻问切:查看 mysql-bin.000003 日志文件中记录的 Python 菇凉的操作,找到上一步的状态位置。

show binlog events in 'mysql-bin.000003';

确诊:从 binlog 的事件中可以看断出执行 Python 菇凉执行 drop database t_t 语句前的 position 节点为 3938,所以恢复开始的 pos 节点为 3847,停止的 pos 节点为 3938 。

施药:采用 mysqlbinlog 完成恢复,治疗效果杠杠滴,神奇的是数据库也回来啦。

mysqlbinlog /usr/local/mysql/data/mysql-bin.000003 --start-position 3847 --stop-position 3938 | mysql -u root -p

秘诀三:应试技巧


又到年底了,有人已经按奈不住想试试机会啦!

灵魂一问:MySQL 主从复制怎么实现的?不多说,就放一图,自行感悟!

灵魂二问:MySQL binlog 的格式有几种?

binlog 的格式有三种:STATEMENT、ROW、MIXED 。
STATMENT:每一条会修改数据的 SQL 语句会记录在 binlog 中。
ROW:不记录每一条 SQL语句的上下文信息,仅记录哪条记录被修改。
MIXED:以上两种模式的混合使用,一般的复制使用STATEMENT模式保存binlog,对于STATEMENT模式无法复制的操作使用ROW模式保存binlog,MySQL会根据执行的 SQL 语句选择日志保存方式。

最后,还是没有抓住感恩节的尾巴,不过还是要感谢一直关注“一猿小讲”公众号的朋友们,因为你们的关注,才有了我一直前行的动力,再次感谢你们的关注!

好了,今天的分享,到这就结束啦,希望你们能够喜欢,芸芸众生,相遇相识便是缘,你我之间的距离,其实就差了一个“在看

推荐阅读:

爱情36技之追美妹的技术

爱情36技之暗送秋波的技术

爱情36技之记忆永存

爱情36技之记忆重生相关推荐

  1. 【Java技术系列】爱情36技之记忆永存

    [这是一猿小讲的第 32 篇原创分享] 1.  关注"一猿小讲"公众号的伙伴们都清楚,Java 那小子带着心爱的 Python 菇凉,去了一趟浪漫的土耳其,然后一起又去了东京和巴黎 ...

  2. 爱情36技之一劳永逸

    [这是一猿小讲的第 41 篇原创分享] 今天雅兴又起,再续爱情36技.大概率你们已经淡忘了 Java 那小子与 Python 菇凉浪漫的爱情故事,容我再帮着给大家回味一下. Java 那小子先是靠着& ...

  3. 【Java技术系列】爱情36技之猿门授渔

    上面蓝色"一猿小讲"点击加关注 觉得好看,记得再设置"星标"哦 [这是一猿小讲的第 29 篇原创分享] 1. 授人以鱼,不如授人以渔.就用上面两张图片展开今天的 ...

  4. 【Java技术系列】爱情36技之趣味相投

    [这是一猿小讲的第 27 篇原创分享] 1. 鲁迅先生曾经说:两个人志同道合,爱情才能走得长久. 我们老百姓常说:磨刀不误砍柴工:工欲善其事必先利其器. 准备好小板凳,今天的故事就从这两句不搭边的话开 ...

  5. 【Java技术系列】爱情36技之暗送秋波的技术

    [这是一猿小讲的第 26 篇原创分享] 1. 这篇文章想分享已经很久了,苦于皱巴巴的技术比较生涩难懂,迟迟没有找到好的分享方式,今天结合爱情中暗送秋波的故事的形式,尝试分享一下. 以后如果再有人问你们 ...

  6. 【Java技术系列】爱情36技之Bug大战

    [这是一猿小讲的第 28 篇原创分享] 1. 鲁迅先生说:程序员,天不怕地不怕,就怕小虫儿爬呀爬,爬呀爬. 随着时间的推移,鲁迅先生又说:真正勇猛的程序员,敢于让虫子面对惨淡的虫生. 虫子在程序员心中 ...

  7. 【Java技术系列】爱情36技之追美妹的技术

    [这是一猿小讲的第 25 篇原创分享] 1. 在古老的非洲大陆上,有个原始人无意中抬头仰望星空,凝视的时间稍微长了一些,超过了外星人设置的阈值,立刻拉响了人类即将产生文明的警报.因为外星人认为,人类已 ...

  8. 定期总结,及时复盘,三省吾身。

    岁月蹉跎,时不我待.不知不觉,2020 年,上半年快过去啦. 今天,花几分钟,对这段时间分享的 100 多篇原创文章,进行整理,以便大家阅读,如果你错过一些精彩的文章,今天绝对是一个补票的好机会.点击 ...

  9. 程序慢的像蜗牛,我该怎么办?

    [这是一猿小讲的第 34 篇原创分享] 1. "一猿小讲"公众号的风格就是多元化,偶尔会真情吐露一下程序猿的内心:偶尔也结合自己的经历畅聊一些经验杂谈:其中也不乏幽默风趣的技术故事 ...

最新文章

  1. vs code中使用Astyle排版C/C++代码
  2. C# 派生类的XmlSerializer序列化XML
  3. snort create_mysql_入侵检测系统Snort+Base安装
  4. 使用application log 分析navigation target解析错误
  5. Github如何更新Fork的仓库
  6. Eclipse 安装 svn
  7. GIT仓库瘦身及GIT LFS迁移说明
  8. 微信小程序点餐系统需求分析与建模
  9. px和毫米的换算_px和厘米怎么换算?
  10. 团队合作开发常用git操作
  11. /NOENTRY在VS里面的设置位置
  12. MIPI 打怪升级之DSI篇
  13. 华为OD机试真题 Python 实现【数字涂色】
  14. 柳叶刀| 肠道微生物群在神经系统疾病中的作用
  15. # 互动媒体期末作业——P5.js“画板”
  16. 修改Markdown表格对齐方式、markdown表格内单元格换行
  17. 【转】前端图片该保存为什么格式?png or jpg?
  18. javascript-按圆形排列DIV元素(一)---- 分析
  19. java计算机毕业设计社区生活超市管理系统源程序+mysql+系统+lw文档+远程调试
  20. Unity插件使用(2)_剖切插件CrossSection(HDRP)

热门文章

  1. pillow库可视化小错误
  2. Linux CPU状态管理
  3. NOTEBOOK_1电子元器件
  4. HP ProLiant 服务器 - POST 错误消息和蜂鸣代码(8)1700 系列错误消息
  5. Windows服务器项目环境搭建
  6. APP手机应用(android和ios)接口(restcontroller, @ResponseBody)
  7. 小技巧 | 用示波器测量串口波特率
  8. C语言socket getsockopt() setsockopt()函数(获取和设置套接口的选项?)(套接字级别SOL_SOCKET)
  9. Redis集群技术架构
  10. 亚马逊僵尸listing采集工具无主asin