mysql主主同步两个数据库同时写入,实现原理:自动增长主键不重复
2017-12-18 11:44
916 查看
出现的问题(多主自增长ID重复)
解决方法:
我们只要保证两台服务器上插入的自增长数据不同就可以了
如:A查奇数ID,B插偶数ID,当然如果服务器多的话,你可以定义算法,只要不同就可以了
在这里我们在A,B上加入参数,以实现奇偶插入
A:my.ini上加入参数
auto_increment_offset = 1
auto_increment_increment = 2
这样A的auto_increment字段产生的数值是:1, 3, 5, 7, …等奇数ID了
B:my.ini上加入参数
auto_increment_offset = 2
auto_increment_increment = 2
这样B的auto_increment字段产生的数值是:2, 4, 6, 8, …等偶数ID了
可以看出,你的auto_increment字段在不同的服务器之间绝对不会重复,所以Master-Master结构就没有任何问题了。当然,你还可以使用3台,4台,或者N台服务器,只要保证auto_increment_increment = N 再设置一下auto_increment_offset为适当的初始值就可以了,那样,我们的MySQL可以同时有几十台主服务器,而不会出现自增长ID重复。
在这里我们说的是2台MYSQL服务器,你也可以扩展到多台,实现方法类似
A -> B -> C-> D ->A
这样一个环形的备份结构就形成了,最后可要记住 自增长ID(主键)要设计好哦,否则会出错的。
转载:http://blog.51cto.com/sndapk/922606
解决方法:
我们只要保证两台服务器上插入的自增长数据不同就可以了
如:A查奇数ID,B插偶数ID,当然如果服务器多的话,你可以定义算法,只要不同就可以了
在这里我们在A,B上加入参数,以实现奇偶插入
A:my.ini上加入参数
auto_increment_offset = 1
auto_increment_increment = 2
这样A的auto_increment字段产生的数值是:1, 3, 5, 7, …等奇数ID了
B:my.ini上加入参数
auto_increment_offset = 2
auto_increment_increment = 2
这样B的auto_increment字段产生的数值是:2, 4, 6, 8, …等偶数ID了
可以看出,你的auto_increment字段在不同的服务器之间绝对不会重复,所以Master-Master结构就没有任何问题了。当然,你还可以使用3台,4台,或者N台服务器,只要保证auto_increment_increment = N 再设置一下auto_increment_offset为适当的初始值就可以了,那样,我们的MySQL可以同时有几十台主服务器,而不会出现自增长ID重复。
在这里我们说的是2台MYSQL服务器,你也可以扩展到多台,实现方法类似
A -> B -> C-> D ->A
这样一个环形的备份结构就形成了,最后可要记住 自增长ID(主键)要设计好哦,否则会出错的。
转载:http://blog.51cto.com/sndapk/922606
相关文章推荐
- mysql主主同步两个数据库同时写入,实现原理:自动增长主键不重复
- mysql主主同步两个数据库同时写入,实现原理:自动增长主键不重复
- php实现mysql两个数据库中表的数据同步
- Linux下keepalived+Mysql主主同步实现数据库高可用实践
- MySQL创建触发器实现统一主机下两个数据库的表同步
- Keepalived+MySQL主主数据同步实现数据库高可用(HA)
- 【转】 mysql使用federated引擎实现远程访问数据库(跨网络同时操作两个数据库中的表)
- mysql使用federated引擎实现远程访问数据库(跨网络同时操作两个数据库中的表)
- web服务文件更新自动同步、数据库主从复制、shell脚本实现网站代码备份和mysql备份
- Mysql,SqlServer,Oracle,sqlite 主键自动增长的设置
- CentOS下Mysql实现数据库主从同步
- 实现TEXTAREA数据写入数据库后提取出来原样显示在网页TABLE上并自动换行
- 怎样将数据同时插入两个表中(事物开始后,插入语句后,自动增长列有没有生成一个值,有的话,值怎样获得)
- Mysql Replication实现mysql主从库自动同步安装指南
- zmud之自动解谜:不用数据库实现自动解谜的原理。
- 如何实现两个数据库同步
- Mysql,SqlServer,Oracle主键自动增长的设置
- Mysql,SqlServer,Oracle主键自动增长的设置
- 实现两个数据库的同步***
- CentOS下Mysql实现数据库主从同步