加入收藏 | 设为首页 | 会员中心 | 我要投稿 东莞站长网 (https://www.0769zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

删库不跑路-详解MySQL数据恢复

发布时间:2019-08-21 03:47:48 所属栏目:MySql教程 来源:程淇铭
导读:日常工作中,总会有因手抖、写错条件、写错表名、错连生产库造成的误删库表和数据的事情发生,那么,如果连数据都恢复不了,还要什么 DBA。 1 前言 数据恢复的前提的做好备份,且开启 binlog, 格式为 row。如果没有备份文件,那么删掉库表后就真的删掉了,

  5.恢复增量数据

  1. [mysql@mysql-test ~]$ mysql -S /tmp/mysql.sock < backup_inc_1.sql  
  2. [mysql@mysql-test ~]$ mysql -S /tmp/mysql.sock < backup_inc_2.sql 

恢复后状态,可以看到已经跳过了 drop 语句

  1. chgnqm-3306>>show tables;  
  2. +------------------+  
  3. | Tables_in_mytest |  
  4. +------------------+  
  5. | a                |  
  6. | b                |  
  7. +------------------+  
  8. 2 rows in set (0.00 sec)  
  9. chgnqm-3306>>select count(*) from a;  
  10. +----------+  
  11. | count(*) |  
  12. +----------+  
  13. |      274 |  
  14. +----------+  
  15. 1 row in set (0.00 sec) 

4.1.2 开启 GTID

使用 GTID 可以直接跳过错误的 SQL

  1.  找出备份时的日志位置
  2.  找出执行了 drop table 语句的 GTID 值
  3.  导出备份时日志位置到最新的 binglog 日志
  4.  恢复备份文件
  5.  跳过这个 GTID   
  1. SET SESSION GTID_NEXT='对应的 GTID 值';  
  2.     BEGIN; COMMIT;  
  3.     SET SESSION GTID_NEXT = AUTOMATIC; 

     6.  应用步骤 3 得到的增量 binlog 日志

4.2 使用延迟库跳过

4.2.1 不开启 GTID

使用延迟库恢复的关键操作在于 start slave until

我在测试环境搭建了两个 MySQL 节点,节点二延迟600秒,新建 a,b 两个表,每秒插入一条数据模拟业务数据插入。

  1. localhost:3306 -> localhost:3307(delay 600) 

当前节点二状态

  1. chengqm-3307>>show slave status G;  
  2. ...  
  3.                   Master_Port: 3306  
  4.                 Connect_Retry: 60  
  5.               Master_Log_File: mysql-bin.000039  
  6.           Read_Master_Log_Pos: 15524  
  7.                Relay_Log_File: mysql-relay-bin.000002  
  8.                 Relay_Log_Pos: 22845  
  9.         Relay_Master_Log_File: mysql-bin.000038  
  10.              Slave_IO_Running: Yes  
  11.             Slave_SQL_Running: Yes  
  12. ...  
  13.         Seconds_Behind_Master: 600  
  14. ... 

当前节点二表

  1. chengqm-3307>>show tables;  
  2. +------------------+  
  3. | Tables_in_mytest |  
  4. +------------------+  
  5. | a                |  
  6. | b                |  
  7. +------------------+ 

在节点一删除表 b

  1. chengqm-3306>>drop table b;  
  2. Query OK, 0 rows affected (0.00 sec)  
  3. chengqm-3306>>show tables;  
  4. +------------------+  
  5. | Tables_in_mytest |  
  6. +------------------+  
  7. | a                |  
  8. +------------------+  
  9. 1 row in set (0.00 sec) 

接下来就是跳过这条 SQL 的操作步骤

  1.延迟库停止同步

  1. stop slave; 

(编辑:东莞站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

热点阅读