测量从服务器延时 (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 |