码迷,mamicode.com
首页 > 数据库 > 详细

Mysql5.7 半同步改进

时间:2017-07-18 13:25:12      阅读:150      评论:0      收藏:0      [点我收藏+]

标签:before   master   恢复   策略   数据   半同步   sync   int   同步   

Mysql5.6半同步策略

Mysql 5.6在半同步的时候,采用的是After Commit策略。即在主库上commit了之后,等待从库返回确认。

在这里,首先会出现幻读的问题,即当前连接的事务读取不到这条记录,而其他连接因为主库已经提交了事务,所以能读取到这条记录。

其次,如果在主库等待从库确认的过程中,主库宕机。此时有两种情况:

1. 事务还没有提交到从库。此时客户端会得到失败的结果。此时如果从库切换为主库,主库恢复变为从库,客户端提交数据到原来的从库,就会发现原来的主库上数据被重复提交。

2. 事务已经提交到从库。此时主库向客户端返回提交失败,而从库已经提交了事务。再次提交的时候,从库便会多出一个事务。

Mysql5.7上半同步的改进

Mysql5.7上,主从的同步等待由主库提交之后等待改为了主库提交之前等待,即 Before Commit。这样就保证了从库在提交了事务之后,主库才会提交事务并返回。从一定程度上解决了主从不一致的问题。

并且,在Mysql5.7上提供了rpl semi sync master wait_point配置,来决定半同步在什么地方等待从库返回。

rpl_semi_sync_master_wait_point

AFTER

SYNC

新的半同步方案,Waiting Slave dump在Storage Commit之前。

COMMIT

老的半同步方案,Waiting Slave dump在Storage Commit之后。

Mysql5.7 半同步改进

标签:before   master   恢复   策略   数据   半同步   sync   int   同步   

原文地址:http://www.cnblogs.com/qiumingcheng/p/7199589.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!