复制心跳是MySQL主从复制中主库定期向从库发送空事件以维持连接的机制,通过设置MASTER_HEARTBEAT_PERIOD参数控制发送频率,需小于slave_net_timeout值以避免连接超时断开。
MySQL 配置复制心跳主要是通过 MASTER_HEARTBEAT_PERIOD 参数来实现的。这个参数用于控制主库向从库发送心跳信号的频率,确保在没有数据变更时也能维持复制连接的活跃状态,避免因网络超时导致连接中断。
什么是复制心跳?
在 MySQL 主从复制中,如果主库长时间没有写操作,IO线程可能会因为等待事件超时而断开连接。心跳机制就是让主库定期向从库发送一个空事件(Heartbeat Event),告诉从库“我还活着”,从而保持连接不断开。
设置心跳周期的方法
可以在执行 CHANGE MASTER TO 命令时指定心跳周期,单位是秒,支持小数(如 2.5)。
CHANGE MASTER TO MASTER_HOST=’master_host_ip’, MASTER_USER=’repl’, MASTER_PASSWORD=’password‘, MASTER_PORT=3306, MASTER_HEARTBEAT_PERIOD=5;
上面的例子将心跳周期设为每 5 秒一次。
也可以在已有复制关系上修改:
STOP SLAVE; CHANGE MASTER TO MASTER_HEARTBEAT_PERIOD=10; START SLAVE;
如何选择合适的心跳周期?
- 心跳间隔应小于 slave_net_timeout 的值,推荐设置为该值的 75% 左右。例如 slave_net_timeout=30,则 heartbeat_period 可设为 20 或更小。
- 太短的心跳周期会增加网络和主库负载,但能更快检测到主库异常。
- 太长可能无法及时感知主库宕机,影响高可用切换速度。
查看当前心跳设置:
SELECT MASTER_HEARTBEAT_PERIOD FROM performance_schema.replication_connection_configuration;
自动配置建议
MySQL 通常会根据 slave_net_timeout 自动计算一个合理的心跳周期,如果你未手动设置,系统会按公式自动设定。但生产环境建议显式配置,避免意外。
检查相关参数:
SHOW VARIABLES LIKE ‘slave_net_timeout’;
基本上就这些。只要在 CHANGE MASTER TO 时加上 MASTER_HEARTBEAT_PERIOD,并结合 slave_net_timeout 合理设置,就能有效防止复制连接空闲断开。