如何配置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
- [642] Go Reflect 性能
- [28] 正态分布的前世今生(一)
- [18] Linux Used内存到底哪里去了?
- [16] rsync同步的艺术
- [16] 基于HTTP缓存轻松实现客户端应用的离线支持
- [14] 在JavaScript中什么时候使用==是正
- [14] Linux内存中的Cache真的能被回收么?
- [13] Cuckoo Filter:设计与实现
- [13] 我的git笔记
- [12] 公钥私钥加密解密数字证书数字签名详解