文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

MySQL中怎么通过binlog日志恢复数据

2024-04-02 19:55

关注

本篇文章为大家展示了MySQL中怎么通过binlog日志恢复数据,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

一、数据备份

操作的前一天晚上进行了日常逻辑备份

mysqldump -uroot -pmysql -P3306 --all-databases > /mysql/backup/dump/alldb_bak.sql

二、模拟事故

模拟事故发生前后的业务情况

mysql> show tables;
+----------------+
| Tables_in_test |
+----------------+
| kk             |
| t1             |
| t2             |
| t3             |
| t4             |
| t5             |
| t6             |
| t7             |
+----------------+
8 rows in set (0.00 sec)
mysql> desc t7;
+-------+-------------+------+-----+---------+----------------+
| Field | Type        | Null | Key | Default | Extra          |
+-------+-------------+------+-----+---------+----------------+
| id    | int(11)     | NO   | PRI | NULL    | auto_increment |
| name  | varchar(30) | YES  |     | NULL    |                |
+-------+-------------+------+-----+---------+----------------+
2 rows in set (0.00 sec)
mysql> create table t8 as select * from t7;
Query OK, 3 rows affected (0.17 sec)
Records: 3  Duplicates: 0  Warnings: 0
mysql> select * from t8;
+----+--------+
| id | name   |
+----+--------+
|  1 | steven |
|  3 | steven |
|  4 | steven |
+----+--------+
3 rows in set (0.00 sec)
mysql> insert into t8 select * from t7;
Query OK, 3 rows affected (0.04 sec)
Records: 3  Duplicates: 0  Warnings: 0
mysql> select * from t8;
+----+--------+
| id | name   |
+----+--------+
|  1 | steven |
|  3 | steven |
|  4 | steven |
|  1 | steven |
|  3 | steven |
|  4 | steven |
+----+--------+
6 rows in set (0.00 sec)
mysql> update t8 set id=2 where id=3;
Query OK, 2 rows affected (0.33 sec)
Rows matched: 2  Changed: 2  Warnings: 0
mysql> update t8 set id=3 where id=4;
Query OK, 2 rows affected (0.03 sec)
Rows matched: 2  Changed: 2  Warnings: 0
mysql> select * from t8;
+----+--------+
| id | name   |
+----+--------+
|  1 | steven |
|  2 | steven |
|  3 | steven |
|  1 | steven |
|  2 | steven |
|  3 | steven |
+----+--------+
6 rows in set (0.00 sec)
mysql> drop table t8;
Query OK, 0 rows affected (0.10 sec)

三、查看当前binlog

mysql> show master status ;
+------------------+----------+--------------+------------------+-------------------+
| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+------------------+----------+--------------+------------------+-------------------+
| mysql-bin.000001 |     1344 |              |                  |                   |
+------------------+----------+--------------+------------------+-------------------+
1 row in set (0.00 sec)

四、恢复数据

拷贝生产库前一天晚上的备份文件以及备份到事故期间的binlog至临时库

scp alldb_bak.sql 192.168.8.32:/mysql/backup/dump/
scp /mysql/data/mysql-bin.000001 192.168.8.32:/mysql/backup/dump/

在临时库创建出现事故的database

mysql> create database test;
Query OK, 1 row affected (0.03 sec)
mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| sys                |
| test               |
| testdb13           |
| testdb14           |
| testdb15           |
| testdb16           |
| testdb17           |
| testdb18           |
| testdb19           |
| testdb20           |
| testdb21           |
| testdb22           |
| testdb23           |
| testdb24           |
+--------------------+
17 rows in set (0.00 sec)

从备份中恢复test数据库

mysql -uroot -pmysql -P3306 -o test < alldb_bak.sql

-o是指单独恢复test库,忽略其他数据库

从mysql-bin.000001中查看到drop table t8之前的pos是1164

update t8 set id=3 where id=4
;
# at 1133
#181127 14:12:41 server id 330631  end_log_pos 1164 CRC32 0x1203751c 	Xid = 1661
COMMIT;
# at 1164
#181127 14:12:53 server id 330631  end_log_pos 1229 CRC32 0x48fad728 	Anonymous_GTID	last_committed=4	sequence_number=5	rbr_only=no
SET @@SESSION.GTID_NEXT= 'ANONYMOUS';
# at 1229
#181127 14:12:53 server id 330631  end_log_pos 1344 CRC32 0x2a7eb0d7 	Query	thread_id=3	exec_time=1	error_code=0
SET TIMESTAMP=1543299173;
DROP TABLE `t8` 
;
mysqlbinlog --no-defaults --stop-position=1164 --database=test mysql-bin.000001 |mysql -uroot -p test

五、根据临时库的数据,将该表恢复至生产库

六、数据验证

mysql> use test;
Database changed
mysql> show tables;
+----------------+
| Tables_in_test |
+----------------+
| kk             |
| t1             |
| t2             |
| t3             |
| t4             |
| t5             |
| t6             |
| t7             |
| t8             |
+----------------+
9 rows in set (0.01 sec)
mysql> select * from t8;
+----+--------+
| id | name   |
+----+--------+
|  1 | steven |
|  2 | steven |
|  3 | steven |
|  1 | steven |
|  2 | steven |
|  3 | steven |
+----+--------+
6 rows in set (0.00 sec)

上述内容就是MySQL中怎么通过binlog日志恢复数据,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注亿速云行业资讯频道。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     801人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     348人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     311人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     432人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     220人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯