MySQL多主结构(比如: MGR Multi Master模式),如果多主都可以写的话,很有可能出现更新丢失的情况.
定义: T1时间,T2时间,T3时间
定义: 事务A, 事务B
Node1节点事务A和Node2节点事务B,在T1时间,事务A, 事务B 都读取了old值n1和n2 : old.value = 100;
select value from tb where id=10; (value=n1=100)
select value from tb where id=10; (value=n2=100)
在T2时间,Node1节点事务A基于old值n1进行了更新: update tb set value=20 where id=10; 此时value=n1=20
在T3时间,Node2节点事务B基于old值n2进行了更新: update tb set value=200 where id=10; 此时value=n2=200
最终在T3时间由Node2节点事务B对old值进行的更新覆盖了在T2时间由Node1节点事务A对old值进行的更新,所以value=200.
在MySQL多主结构环境中,如何避免更新丢失?
MySQL多主结构结构,很好的解决了单主结构选主切换带来的麻烦,但在高并发的环境不可避免的带来了更新丢失的问题,为了更好的利用多主的优势,多主可写必须只能把写放在同一个节点上进行.