master_pos_wait函数与MySQL主从切换

php中文网
发布: 2016-06-07 17:24:02
原创
1419人浏览过

主从切换是高可用MySQL架构的必要步骤(即使用不发生,也要有备无患)。一般设置为双M(M1、M2),假设当前状态为写M1,而M2只读

背景
 
  主从切换是高可用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    其他返回值:若当前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) 在追上的第一时间就能感知,否则可能多等若干秒

linux

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
热门推荐
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号