- 深入理解MySQL主从原理
- 高鹏
- 420字
- 2021-04-16 16:29:22
1.4.3 搭建GTID AUTO_POSITION MODE的主从
在这一部分中,获取gtid-purged变量是需要注意的地方,也是笔者在线上遇到的一个“坑”,这个“坑”还比较普遍。简单来说,就是在MySQL 5.7的某些版本中,导入数据会覆盖原本命令set gtid_purged的设置,而gtid_executed表并不是实时更新的,因此在从库重启后可能导致数据重复拉取,进而导致主从同步报错。
注意,主备库必须开启GTID并设置好server_id:
![](https://epubservercos.yuewen.com/A01218/19823444008569806/epubprivate/OEBPS/Images/txt001_30.jpg?sign=1738872486-dpVbf5vVstPc4vEWmzxMAhgI5QLznioW-0-910c63d0c0000b8a95bf6394a658c84e)
同时,主从库都开启 binary log。如果不设置级联从库,那么从库不需要开启参数log_slave_updates。
(1)建立复制用户并且授权。
![](https://epubservercos.yuewen.com/A01218/19823444008569806/epubprivate/OEBPS/Images/txt001_31.jpg?sign=1738872486-YFKWZw3gUCwFbARLMnwNkXkzA30AimNW-0-8edaf3131b967217d2cb145434f68604)
(2)导出数据。
![](https://epubservercos.yuewen.com/A01218/19823444008569806/epubprivate/OEBPS/Images/txt001_32.jpg?sign=1738872486-CKZXDZ6QOrkXAh2TslWs0Svamclc5quX-0-4778fa6ec70f33df5a8a56e42e2f4f62)
(3)从库导入数据。
使用命令mysql-e "source xxx.sql" 导入数据。
(4)从库执行reset master命令。
这一步主要防止gtid_executed表在导入数据的过程中被覆盖,我们在MySQL 5.7的某些版本中遇到过这种情况。一旦从库再次重启,读取 gtid_executed 表就会得到错误的 gtid_executed变量,进而导致从库启动失败。因此最好重新设置gtid_purged变量。
![](https://epubservercos.yuewen.com/A01218/19823444008569806/epubprivate/OEBPS/Images/txt001_33.jpg?sign=1738872486-IJZIvNKMbKqOMJL72lkXdCEH4HptxjY8-0-fd6b930f5b160e8779d46b1c646ae48a)
(5)提取gtid_purged变量,并且执行。
使用head-n 40命令可以快速得到gtid_purged变量,例如:
![](https://epubservercos.yuewen.com/A01218/19823444008569806/epubprivate/OEBPS/Images/txt001_34.jpg?sign=1738872486-xtWlYJ4oKEL2Gzbc0Zhz4fnSjImNPuYA-0-39249f5883802a926f920f7a23903a93)
执行
![](https://epubservercos.yuewen.com/A01218/19823444008569806/epubprivate/OEBPS/Images/txt001_35.jpg?sign=1738872486-WW0pUJPahWiXKOegLiTRYex67cB6aeB8-0-50c25328492cbabf75591540df8ce1aa)
即可,完成本步骤后,mysql.gtid_executed表会重构,这个我们在1.2节的通用修改时机中已经讨论过了。
(6)使用MASTER_AUTO_POSITION建立同步。
![](https://epubservercos.yuewen.com/A01218/19823444008569806/epubprivate/OEBPS/Images/txt001_36.jpg?sign=1738872486-sLLEA60ofkC7kzQi8txzBITdNqVIoCon-0-0096f39595e33f66db9977b39879146f)
![](https://epubservercos.yuewen.com/A01218/19823444008569806/epubprivate/OEBPS/Images/txt001_37.jpg?sign=1738872486-G7VfKtezUW28q4cEJuZu9MIYzAM8D8xh-0-5dbb225f77c922f8fb6ee7bf205f09cd)
(7)启动slave。
![](https://epubservercos.yuewen.com/A01218/19823444008569806/epubprivate/OEBPS/Images/txt001_38.jpg?sign=1738872486-avXJ02uaYtAaGniRNbmQQQ8sF2vis7cu-0-7df2bb07eb24039db02416131f7820aa)