MySQL如何恢复误操作

这篇文章给大家分享的是有关MySQL如何恢复误操作的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

十多年的华蓥网站建设经验,针对设计、前端、开发、售后、文案、推广等六对一服务,响应快,48小时及时工作处理。全网营销推广的优势是能够根据用户设备显示端的尺寸不同,自动调整华蓥建站的显示方式,使网站能够适用不同显示终端,在浏览器中调整网站的宽度,无论在任何一种浏览器上浏览网站,都能展现优雅布局与设计,从而大程度地提升浏览体验。成都创新互联从事“华蓥网站设计”,“华蓥网站推广”以来,每个客户项目都认真落实执行。

常用的恢复方式
2.1 利用备份恢复
  使用这种方式的前提必须有最近的备份集或者知道出现误操作起始的binlog 位点或者GTID,利用备份集恢复到中间的机器上,然后利用MySQL的slave 特性

  1. START SLAVE [SQL_THREAD] UNTIL

  2.     MASTER_LOG_FILE = 'log_name', MASTER_LOG_POS = log_pos;

  3. until_option:

  4.     UNTIL {   {SQL_BEFORE_GTIDS | SQL_AFTER_GTIDS} = gtid_set

  5.           | MASTER_LOG_FILE = 'log_name', MASTER_LOG_POS = log_pos

  6.           | RELAY_LOG_FILE = 'log_name', RELAY_LOG_POS = log_pos

  7.           | SQL_AFTER_MTS_GAPS  }

恢复出到一个临时的实例,将误删除,更新的数据 dump 出来并恢复到老的实例里面。恢复数据期间的受影响的表最好不可写,否则将难以达到最想要的结果。例如
a=2 ,被误更新为 a=4,恢复的期间有被更新为a=7 ,结果恢复后又恢复为a=2 。
此种恢复方式 不适合恢复大量数据库,且需要临时实例。
2.2 利用开源工具binlog2sql 恢复。
  binlog2sql 是大众点评公司的DBA 开发的一款基于通过解析binlog将delete 恢复为insert,update 的值 set 字段和where条件做对调的原理来恢复数据的。
  使用限制 MySQL的binlog format 必须是row 
安装

  1. git clone https://github.com/danfengcao/binlog2sql.git && cd binlog2sql

  2. pip install -r requirments.txt

用法

  1. usage: binlog2sql.py [-h HOST] [-u USER] [-p PASSWORD] [-P PORT]

  2.                      [--start-file STARTFILE] [--start-position STARTPOS]

  3.                      [--stop-file ENDFILE] [--stop-position ENDPOS]

  4.                      [--start-datetime STARTTIME] [--stop-datetime STOPTIME]

  5.                      [--stop-never] [--help] [-d [DATABASES [DATABASES ...]]]

  6.                      [-t [TABLES [TABLES ...]]] [-K] [-B]

例子

  1. create table flashback(

  2. id int(11) not null auto_increment  primary key ,

  3. stat int(11) not null default 1

  4. ) engine=innodb default charset=utf8;

  5. insert into flashback(stat) values (2),(3),(4),(7),(9),(22),(42),(33),(66),(88)

误操作

  1. update flashback set stat=15

恢复数据的步骤
1 获取误操作的dml所在的binlog,不过一般开发可不知道具体binlog,他们只知道什么时间误操作了,binlog2sql支持按照时间范围恢复。

  1. mysql> show master logs;

  2. +------------------+-----------+

  3. | Log_name | File_size |

  4. +------------------+-----------+

  5. | mysql-bin.000009 | 177 |

  6. | mysql-bin.000010 | 464 |

  7. | mysql-bin.000011 | 8209 |

  8. +------------------+-----------+

  9. 3 rows in set (0.00 sec)

本例子中binlog为mysql-bin.000011

2 利用binlog2sql 恢复数据,先解析binlog获取 update 语句的起始位点,本例中  start 5087 end 5428

  1. python binlog2sql.py -h227.0.0.1 -P3307 -udba -p'dbadmin' -dyang -tflashback --start-file='mysql-bin.000011'

MySQL如何恢复误操作
使用binlog2sql -B 参数得到恢复的sql
MySQL如何恢复误操作
将获取到的sql 执行到数据库,假如生产环境中真的发生了问题,一定要和开发沟通并且确认需要恢复的确切记录。

  1. mysql> select * from flashback;

  2. +----+------+

  3. | id | stat |

  4. +----+------+

  5. | 1 | 2 |

  6. | 2 | 3 |

  7. | 3 | 4 |

  8. | 4 | 7 |

  9. | 5 | 9 |

  10. | 6 | 22 |

  11. | 7 | 42 |

  12. | 8 | 33 |

  13. | 9 | 66 |

  14. | 10 | 88 |

  15. +----+------+

  16. 10 rows in set (0.00 sec)

binlog2sql的限制
   mysql server必须开启,离线模式下不能解析
优点(对比mysqlbinlog)
   纯Python开发,安装与使用都很简单
   自带flashback、no-primary-key解析模式,无需再装补丁
   flashback模式下,更适合闪回实战
   解析为标准SQL,方便理解、调试
   代码容易改造,可以支持更多个性化解析
其实MySQL 还提供了一个参数 sql_safe_updates,该参数将禁止 不带where 条件的delete和update语句。

感谢各位的阅读!关于“MySQL如何恢复误操作”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!


名称栏目:MySQL如何恢复误操作
当前路径:http://pcwzsj.com/article/jedjoj.html