MariaDB社区
标题: 尽可能准确的测量从服务器延时情况 [打印本页]
作者: kider 时间: 2013-4-23 09:57
标题: 尽可能准确的测量从服务器延时情况
测量从服务器延时
(show slave status,seconds_behind_master从理论上显示了从服务器的延迟,事实上它并不总是准确的,原因:
- 从服务器计算seconds_behind_master的方式是比较服务器当前的时间戳和二进制日志记录的时间戳,因此只有在处理查询的时候才能报告延迟。
- 如果从服务器进程没有运行,从服务器通常报告NULL
- 一些错误(比如,主、从服务器之间的max_allowed_packet设置不匹配,或者不稳定的网络)能中断复制,并且/或者终止从服务器线程,但是seconds_behind_master只会报告0,而不是指出错误。
- 即使从服务器进程正在运行,有时它也不能计算延迟。如果发生了这种情况,从服务器会报告0或NULL。
- 非常长的事务能导致报告的延迟发生波动。例如,如果有事务更新了数据,在一小时内一直保持开启,然后进行提交,更新就会在实际发生之后的一小时才进入日志,它会短暂的报告比主服务器落后了一小时,然后延迟就很快变成0.
- 如果分布服务器落后了,并且有自己的从服务器,从服务器和分布主服务器保持了一致,即使相对于最终的服务器仍然有延迟,报告的值还是0。)
(解决这些问题的办法就是忽略seconds_behind_master,并且使用可以直接观测的测量的工具来测量延迟。一个好的解决办法就是heartbeat record,它是主服务器上每秒更新一次的时间戳。复制动率。 Maatkit里面的mk-heartbeat。)
(以上延迟指标 都不能表示从服务器需要多长时间才能赶上主服务器。依赖于很多因素。)
这个工具现在叫Percona Toolkit
http://www.mysqlpub.com/forum.php?mod=viewthread&tid=33457
作者: laowang 时间: 2013-4-23 10:35
这些都是在linux下运行的工具吧
有没有在win2003下运行的呢?
作者: kider 时间: 2013-4-23 16:26
没这么好的,你可以再找找。
作者: 末猪 时间: 2013-4-23 21:06
好帖,
欢迎光临 MariaDB社区 (http://123.56.88.72/) |
Powered by Discuz! X3.2 |