mysql 主主同步两个数据库同时写入,实现原理:自动增长主键不重复

出现的问题(多主自增长 ID 重复)

解决方法:

我们只要保证两台服务器上插入的自增长数据不同就可以了

如:A查奇数 ID,B 插偶数 ID,当然如果服务器多的话,你可以定义算法,只要不同就可以了


在这里我们在 A,B上加入参数,以实现奇偶插入


A:my.ini 上加入参数


autoincrementoffset = 1

autoincrementincrement = 2

这样 A的 auto_increment 字段产生的数值是:1, 3, 5, 7, …等奇数 ID


B:my.ini 上加入参数


autoincrementoffset = 2

autoincrementincrement = 2

这样 B的 auto_increment 字段产生的数值是:2, 4, 6, 8, …等偶数 ID


可以看出,你的 auto_increment字段在不同的服务器之间绝对不会重复,所以 Master-Master 结构就没有任何问题了。当然,你还可以使用 3 台,4 台,或者 N** 台服务器,只要保证 autoincrementincrement = N 再设置一下 autoincrementoffset** 为适当的初始值就可以了,那样,我们的 MySQL 可以同时有几十台主服务器,而不会出现自增长 ID 重复。


在这里我们说的是 2台 MYSQL 服务器,你也可以扩展到多台,实现方法类似

A -> B -> C-> D ->A

这样一个环形的备份结构就形成了,最后可要记住 自增长 ID(主键)要设计好哦,否则会出错的。