![深入理解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=1739328896-mfhYPDjk8adku6r1fCZwg8KHOrlJ167R-0-d9a78669c380c9df13afb8e61089c173)
首先确定操作都支持GTID,生产环境建议设置本参数后观察一段时间,如果错误日志中输出违反GTID的事务则必须更改。
(2)主库/从库执行。
![](https://epubservercos.yuewen.com/A01218/19823444008569806/epubprivate/OEBPS/Images/txt001_44.jpg?sign=1739328896-e6I1j4zvaI008RCZEcvKDrxjjI1u00qY-0-ea8a7e18f8027c665c631b60a3847121)
这一步一旦执行,违反GTID的操作都将被拒绝,比如create table as select操作。
(3)主库/从库执行。
![](https://epubservercos.yuewen.com/A01218/19823444008569806/epubprivate/OEBPS/Images/txt001_45.jpg?sign=1739328896-paR6PiwP62vr4GBlP8ZI58eFGlUgvVMU-0-138c81a7c0aed1eb7f05a053a046f00a)
主库生成的是匿名事务,从库可以应用匿名和GTID事务。
(4)主库/从库执行。
![](https://epubservercos.yuewen.com/A01218/19823444008569806/epubprivate/OEBPS/Images/txt001_46.jpg?sign=1739328896-Ihp8nq8kmT6hF0gwG0oc4SQLFfBEJgh0-0-d0c57b9bbebb3ce6544304cd4842140f)
主库生成的是GTID事务,从库可以应用匿名和GTID事务。
(5)主库/从库执行。
![](https://epubservercos.yuewen.com/A01218/19823444008569806/epubprivate/OEBPS/Images/txt001_47.jpg?sign=1739328896-EHy5QvI9aPnvVneVicRZQT94PxklHNtf-0-f7097a7d3d0bb59ff0b3d06cf022c436)
确定已经没有匿名的事务。
多观察一段时间,确认这个统计值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=1739328896-SZwDZXVVp8c9Z5ZpF52ooSrET46vW7LD-0-4a5229e3a341ebb5c83c5a88ae407327)
(7)从库执行。
![](https://epubservercos.yuewen.com/A01218/19823444008569806/epubprivate/OEBPS/Images/txt001_49.jpg?sign=1739328896-5OUtCieGIn62O2AwI7K4Hcqdssz23cjx-0-9ba18379955db246f2e5e8dbc412ce68)
到这一步,所有老的relay log都清理掉了,新relay log包含的全是GTID操作Event。
(8)主库/从库执行。
修改配置文件my.cnf,将参数的更改加入配置文件。