主主复制-主主复制时的主键冲突解决
来源:互联网 发布:js array转json对象 编辑:程序博客网 时间:2024/06/06 00:36
1: 2台服务器都设置上二进制日志和relay日志
2: 都设置上replcation账号
3: 都设置对方为自己的master
PS:原理跟主从复制的配置步骤一样,两台主主服务器都需要配置主从相关的配置信息
主主复制下一定要注意避免的问题---------同步冲突
例:
create table stu (
id int primary key auto_increment.
)......
2台mysql地位相等, 假如2个请求同时到达2台服务器,
请求的A节点, stu 的id为1
请求的B 节点, stu的id为1 ,
同步--->冲突
如何解决?
让1台服务器 1,3,5,7来增长
另1台服务器 2,4,6,8来增长
一台服务器:
set global auto_increment_increment = 2;//每步增长2
set global auto_increment_offset = 1; //从1开始增长
set session auto_increment_increment = 2;
set session auto_increment_offset = 1;
另一台服务器:
set global auto_increment_increment = 2;
set global auto_increment_offset = 2;
set session auto_increment_increment=2;
set session auto_increment_offset = 2;
注:auto-increment-increment 和 auto-increment-offset 要写到配置文件 中,防止下次重启后失效.
操作后得到如下类似效果
如果后期需要加服务器,这个办法就有限制了.
我们可以在业务逻辑上来解决,
比如在oracle 有sequnce,序列.
序列每次访问,生成递增/递减的数据.
以redis为例, 我们可以专门构建一个 global:userid
每次PHP插入Mysql前,先 incr->global:userid, 得到一个不重复的userid.
- 主主复制-主主复制时的主键冲突解决
- mysql在主主复制中遇到自增主键冲突的解决办法
- MariaDB的主从复制、主主复制、半同步复制
- MySQL主从复制、基于SSL的主从复制、主主复制、半同步复制
- Mysql复制技术中的主键冲突
- Mysql复制技术中的主键冲突
- 复制中数据冲突解决
- mysql的主主复制
- mysql复制复制切换主主复制开启GTID
- MongoDB主从复制,主主复制
- MySQL主从复制与主主复制
- mysql主从复制,主主复制
- MySQL主从复制与主主复制
- MySQL主从复制与主主复制
- MySQL主从复制与主主复制
- MySQL主从复制与主主复制
- MySQL主从复制与主主复制
- MySQL主从复制与主主复制
- 遗传算法 TSP问题 C++实现 (三)
- 国防科学技术大学第十八届银河之光文化节ACM程序设计竞赛初赛第三场 赛后小结
- dijkstra算法
- Write file 之 excel jxl.jar
- VMware虚拟机下CentOS无法上网解决方法
- 主主复制-主主复制时的主键冲突解决
- 单例设计模式
- 利用Array和LinkedList实现hashMap
- java方法的重载(overloading)和覆盖(override)
- ThinkPad E450(c)添加或者更换内存条的一些问题
- 黑马程序员---网络编程(二)
- [leetcode][Array] Rotate Image
- 2015年NEUACM省赛练习赛第二场 赛后小结
- 色彩模型