![深入理解MySQL主从原理](https://wfqqreader-1252317822.image.myqcloud.com/cover/513/37423513/b_37423513.jpg)
上QQ阅读APP看本书,新人免费读10天
设备和账号都新为新人
1.4.6 在线开启GTID
我们有时候需要在不影响业务的情况下从传统的主从切换为基于GTID的主从,应该执行如下步骤。
(1)主库/从库执行。
![](https://epubservercos.yuewen.com/A01218/19823444008569806/epubprivate/OEBPS/Images/txt001_43.jpg?sign=1738926618-sZp0TYwZasv57chqwYXbBzadklqkw4JY-0-9a1000d9e4eba87eaa16583b27a9bdf2)
首先确定操作都支持GTID,生产环境建议设置本参数后观察一段时间,如果错误日志中输出违反GTID的事务则必须更改。
(2)主库/从库执行。
![](https://epubservercos.yuewen.com/A01218/19823444008569806/epubprivate/OEBPS/Images/txt001_44.jpg?sign=1738926618-eVhdnG4972OynGopdFFcac4ndC9Wxpeo-0-92f9c863b6381c25556c2d25ff0dc872)
这一步一旦执行,违反GTID的操作都将被拒绝,比如create table as select操作。
(3)主库/从库执行。
![](https://epubservercos.yuewen.com/A01218/19823444008569806/epubprivate/OEBPS/Images/txt001_45.jpg?sign=1738926618-gRX1usCS4DN78aZmZylGiOE77YGshnpS-0-96466d451e3afec5021b616559e36871)
主库生成的是匿名事务,从库可以应用匿名和GTID事务。
(4)主库/从库执行。
![](https://epubservercos.yuewen.com/A01218/19823444008569806/epubprivate/OEBPS/Images/txt001_46.jpg?sign=1738926618-VJun4JhQI3Nr5xO2TVg0lhhzkWveyUG8-0-03bc00d2d930acde9c391ad9656782d9)
主库生成的是GTID事务,从库可以应用匿名和GTID事务。
(5)主库/从库执行。
![](https://epubservercos.yuewen.com/A01218/19823444008569806/epubprivate/OEBPS/Images/txt001_47.jpg?sign=1738926618-pQB5m3w1aqGo9B3YUR9notp1E5AyfMJM-0-ce8504a4952b13c8ebe7435b95b6e923)
确定已经没有匿名的事务。
多观察一段时间,确认这个统计值ONGOING_ANONYMOUS_TRANSACTION_COUNT为0,如果不为0,强行修改则可能导致数据丢失,然后确认从库 Retrieved_Gtid_Set、Executed_Gtid_Set正常增长。
到这一步,实际上GTID已经开始使用了。注意这一步非常重要,后面我们单独看看统计值ONGOING_ANONYMOUS_TRANSACTION_COUNT的含义。
(6)主库/从库执行。
![](https://epubservercos.yuewen.com/A01218/19823444008569806/epubprivate/OEBPS/Images/txt001_48.jpg?sign=1738926618-Vvi1ZG2fhnfBPtIX2OdsS9aJzMCxxVKY-0-7becf034647ce5f4bc21ac09ef3e8f4f)
(7)从库执行。
![](https://epubservercos.yuewen.com/A01218/19823444008569806/epubprivate/OEBPS/Images/txt001_49.jpg?sign=1738926618-pedXQgJc9VlCEBvm9ilIDl6ShLHe3Sfn-0-ba947d1a1ce299bbebd5be5c6fa26d34)
到这一步,所有老的relay log都清理掉了,新relay log包含的全是GTID操作Event。
(8)主库/从库执行。
修改配置文件my.cnf,将参数的更改加入配置文件。