master_pos_wait函数与MySQL数据库主从复制切换
来源:互联网 发布:mac上microsoft 编辑:程序博客网 时间:2024/06/11 18:49
背景
主从切换是高可用MySQL架构的必要步骤(即使用不发生,也要有备无患)。一般设置为双M(M1、M2),假设当前状态为写M1,而M2只读,切换的大致流程如下:
1、 停止应用写M1,将M1设置为只读
2、 检查M2的slave status直到赶上M1
3、 将M1设置为可写
其中在第2步细化为
a) 在M1上show master status;得到binlog位置P,因为已经设为只读,不会变化
b) 循环检测M2上的执行位置,若未到P,则过几秒再查。循环直到从库追上。
这里介绍一个函数用于简化步骤b.
函数master_pos_wait
语法 select master_pos_wait(file, pos[, timeout]).
这里的file和pos对应主库show master status得到的值,代表执行位置。 函数逻辑是等待当前从库达到这个位置后返回, 返回期间执行的事务个数。
参数timeout可选,若缺省则无限等待,timeout<=0时与缺省的逻辑相同。若为正数,则等待这么多秒,超时函数返回-1.
其他返回值:若当前slave为启动或在等待期间被终止,返回NULL; 若指定的值已经在之前达到,返回0
master_pos_wait的实现逻辑
用户调用该函数后,根据传入参数调用pthread_cond_timedwait或pthread_cond_wait。 SQL_THREAD线程每次apply完一个事件后会触发更新relay info, 并通知上面等待的线程。因为可能有多个用户等待,因此用广播方式。
关于事件个数的计算比较复杂,有兴趣的同学可以看这篇, 不过在本文讨论的这个问题上,正数返回值并不重要。
小结
用master_pos_wait来实现上面的步骤b,则可以简化为:
b’) 在M上执行select master_pos_wait(file, pos),返回后判断一下返回值>=0 则认为主从同步完成。
好处是
1) 简化逻辑,不用在应用脚本判断
2) 在追上的第一时间就能感知,否则可能多等若干秒
自:http://www.mysqlops.com/2012/10/09/master_pos_wait%E5%87%BD%E6%95%B0%E4%B8%8Emysql%E4%B8%BB%E4%BB%8E%E5%88%87%E6%8D%A2.html
个人观点:上述方法其实不错,但是有点麻烦。,主库上flush tables with read lock,从库看POS值不变化了或等于锁定之后的pos值,主从就复制完毕了。
- master_pos_wait函数与MySQL数据库主从复制切换
- master_pos_wait函数与MySQL数据库主从复制切换
- 主从复制中MASTER_POS_WAIT函数的应用
- window下配置mysql主从复制与主从切换
- mysql主从数据库切换
- Mysql 主从数据库复制
- mysql主从数据库复制
- mysql数据库主从复制
- MySQL三层主从复制切换
- mysql主从复制之主从切换
- mysql数据库实现主从复制
- mysql数据库主从复制配置
- MySQL 数据库主从复制架构
- MySQL 数据库主从复制架构
- MySQL 数据库主从复制架构
- MySQL 数据库主从复制架构
- mysql数据库的主从复制
- Mysql配置数据库主从复制
- 关于MFC 计算器响应键盘消息及虚拟键码
- The word is not correctly spelled问题解决(修改)
- 【省选】算法总结——线段树2
- 拍打
- 近三年,学习开发计划
- master_pos_wait函数与MySQL数据库主从复制切换
- 正则表达式
- windows与linux中文件路径分隔符问题解决--通过File.separator解决掉此问题
- IOS5 ARC unsafe_unretained等说明
- Eclipse CDT 调试C/C++程序设置
- Android--消息推送机制
- Oracle复习 随笔
- linux C 解析.torrent
- 荆棘鸟