mysqlbinlog恢复数据-GTID

mysqlbinlog恢复数据-GTID## 标题
1、数据准备
mysql> use hyc
Database changed
mysql> show tables;
Empty set (0.00 sec)

mysql> show master status\G
*************************** 1. row ***************************
File: mysql-bin.000004
Position: 194
Binlog_Do_DB:
Binlog_Ignore_DB:
Executed_Gtid_Set: 3b9374ec-c643-11ea-b919-000c291a0385:1-39
1 row in set (0.00 sec)

mysql> create table t1(id int ,uname varchar(10));
Query OK, 0 rows affected (0.00 sec)

mysql> insert into t1 values(1,‘aa’),(2,‘bb’);
Query OK, 2 rows affected (0.10 sec)
Records: 2 Duplicates: 0 Warnings: 0

mysql> select * from t1;
±-----±------+
| id | uname |
±-----±------+
| 1 | aa |
| 2 | bb |
±-----±------+
2 rows in set (0.00 sec)

2、查看二进制日志
mysqlbinlog恢复数据-GTID_第1张图片

gtid开始位置:mysql-bin.000004 | 373 | Gtid | 3306 | 438 | SET @@SESSION.GTID_NEXT= ‘3b9374ec-c643-11ea-b919-000c291a0385:41’
gtid结束位置:mysql-bin.000004 | 669 | Xid | 3306 | 700 | COMMIT /* xid=24 */

3、mysqlbinlog解析日志
mysqlbinlog --no-defaults -v mysql-bin.000004 --start-position=373 --stop-position=700
mysqlbinlog恢复数据-GTID_第2张图片
4、开始回滚事务,检查t1表是否有数据
mysqlbinlog --no-defaults -v mysql-bin.000004 --start-position=373 --stop-position=700|mysql -uroot -p123456 --socket=/data/mysql3306/mysql.sock --port=3306
select * from t1; #结果为空,发现事务没有回滚
网上查找资料:源库有已经执行过这个事务,不能重复执行,需要以下参数方可执行
使用–skip-gtids=true 参数
–skip-gtids=xxx的作用为:mysqldump是否使用–skip-gtids=true 参数,要根据情况来定;第一种情况:如果我们是要恢复数据到源数据库或者和源数据库有相同 GTID 信息的实例,那么就要使用该参数。如果不带该参数的话,是无法恢复成功的。因为包含的 GTID 已经在源数据库执行过了,根据 GTID 特性,一个 GTID 信息在一个数据库只能执行一次,所以不会恢复成功。
mysqlbinlog --no-defaults -v --skip-gtids=true mysql-bin.000004 --start-position=373 --stop-position=700|mysql -uroot -p123456 --socket=/data/mysql3306/mysql.sock --port=3306
select * from t1; #数据回滚成功
mysqlbinlog恢复数据-GTID_第3张图片

总结:使用场景
1、如果通过全量+事务回滚的情况下,不使用–skip-gtids=true参数
2、如果在源库中回滚事务则需要跳过GTID(源库有已经执行过这个事务,不能重复执行)

你可能感兴趣的:(mysql,数据库)