如何配置MySQL SemiSyncReplication
SemiSyncReplication是Google提供的一个MySQL patch,作用在于保证至少有一个slave完成了数据同步。
安装的过程很简单,但是要找对路。这里提供一个传送门,看完就会编译安装了:
http://www.realzyy.com/?p=178
SemiSyncReplication需要的MySQL源码包为mysql-5.0.37.tar.gz;需要的patch为mysql-5.0.37_semisync.patch。其他的patch可以不打,但是如果选择mysql-5.0.37-patches来打补丁的话,那么记得要再打上http://www.realzyy.com/?p=178最后提到的那个小补丁。
配置也很简单,主要是三个参数:
master:
rpl_semi_sync_enabled = 1 #configures a master to use semi-sync replication.
rpl_semi_sync_timeout = 10000000 #the timeout in milliseconds for the master.
slave:
rpl_semi_sync_slave_enabled = 1 #configures a slave to use semi-sync replication. The IO thread must be restarted for this to take effect.
要特别注意rpl_semi_sync_timeout这个参数,官网推荐的设置10太短了。我测试了一下,将slave上的replication线程停掉,master上面执行更新操作并不会出现明显的block现象。如果想让master和slave时时刻刻保证一致,那么rpl_semi_sync_timeout就需要设置得很大,至少在DBA能察觉异常之前,不允许master单方面进行更新操作。
扫一扫订阅我的微信号:IT技术博客大学习
- 作者:DBA@Taobao 来源: DBA@Taobao
- 标签: SemiSyncReplicat
- 发布时间:2010-02-25 22:43:52
- [574] WEB系统需要关注的一些点
- [15] 移动音乐产品梳理
- [14] 一次神奇的MySQL优化
- [14] 哪本书是对程序员最有影响、每个程序员都该阅读
- [14] 修改系统最大文件句柄数
- [12] 豆瓣是啥?
- [11] Spark性能优化——和shuffle搏斗
- [11] 内存的惰性初始化
- [11] 一张图帮你看懂 iPhone 的屏幕分辨率
- [11] InnoDB insert性能拐点测试