To avoid infinite replication loops MySQL doesn’t allow you to have log_slave_updates
and replicate-same-server-id
.
When using GTIDs that may lead to something not expected that you may not be aware of.
In this scenario, we have 2 MySQL servers using GTID. The sever uuid part of the GTID has been modified in the illustration to make it more clear. Both servers have log_slave_updates
enabled too:
data:image/s3,"s3://crabby-images/576db/576db022f1c56fe6af7423d5c03e10e32da05e39" alt=""
So far nothing unusual. So let’s write data on the master (MySQL A):
data:image/s3,"s3://crabby-images/962df/962dfd5f3fc6386cc61ff1f191d56a602536a1bb" alt=""
We can see that this first transaction is identified by its GTID where the uuid matches MySQL A and the sequence number is 1. Let’s write some data again:
data:image/s3,"s3://crabby-images/cffb1/cffb1f30688ddafbe14dc95cbaa112540865c08b" alt=""
All good.
Now let’s take a backup on the replica (MySQL B):
data:image/s3,"s3://crabby-images/4a7ba/4a7ba4cecebb18e1bdb380a7cfd1a91704813539" alt=""
Backup is consistent and matches the data on both servers.
Now let’s write again some data:
data:image/s3,"s3://crabby-images/20938/20938fc9513055da37d7c624c4c664b575a628f5" alt=""
Of course the backup that was taken earlier does not change.
All suddenly, MySQL A crashes and goes away… We promote MySQL B as new writer and we use it to write again some data:
data:image/s3,"s3://crabby-images/5f8aa/5f8aa0f27873a9ffd70ca3e7a771d81b70efa97d" alt=""
We can notice that the GTID changed to use the uuid of MySQL B. (This information is contained in the variable gtid_executed
).
It’s time to restore our backup on MySQL A:
data:image/s3,"s3://crabby-images/13501/1350140c5dab4250d4dfe8e7fed16f331e3ef590" alt=""
And we configure MySQL A to become replica of MySQL B:
data:image/s3,"s3://crabby-images/68499/68499f77d8a3e3b9aee54e99e3fff3179262984e" alt=""
Wow ! All the transactions happened after the backup on MySQL A have been ignored !
In fact, this is again to protect our user to have problems like circular replication and infinite loop.
To be able to replicate the missing transaction is to change the server_id
to a new unique value after the restore and before starting replication. Then replication will work as expected:
data:image/s3,"s3://crabby-images/04434/0443426a3e0be1332cef8a6adaa28699c4b09904" alt=""
In summary, if you have enabled log_slave_updates
and you want to recreate a master from a backup taken on a replica, you must change the server_id
. Even if you use GTIDs, server_id
is for the moment still to be taken in consideration.
If you plan to write back on MySQL A, it’s always safer to also change its
server_uuid
to avoid any split-brain situation.