看到了一篇server id导致mysql备份恢复的时候丢失事务的文章,特此重现一下。
主备开启了GTID,实验过程如下:
1.主库执行:
create database test1;
create database test2;
2.主从没有延迟后备份,利用从库备份,物理或者逻辑都可以:
mysqldump -uroot -poracle --single-transaction --master-data=2 --all-databases > dump.sql
3.主库执行:
create database test3;
4.将主库干掉
5.从库提升为主库,并且:
create database test4;
6.利用从库的备份恢复老的主库,并指向新主
这个时候会发现,恢复出来的从库丢失了一个事务test3:
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| ming |
| mysql |
| performance_schema |
| sakila |
| sys |
| test1 |
| test2