Go中Socket心跳检测需客户端每30秒发ping、服务端及时回pong,并维护lastActive时间戳,超时45秒关闭连接;结合TCP Keepalive与退避重连策略实现可靠连接管理。
在 Go 中实现 Socket 心跳检测,核心是客户端与服务端定期互发轻量协议包(如 ping/pong),以判断连接是否存活、及时发现假死或异常断连。关键不在于“发什么”,而在于“怎么发、何时发、发了没回怎么办”。
Go 的 net.Conn 本身不提供心跳机制,需手动实现。推荐在连接建立后,启动独立 goroutine 负责发送心跳包,并监听响应:
[]byte{0x01} 表示 ping)[]byte{0x02}),则判定连接异常光客户端发不够,服务端必须及时回 pong,且要对每个连接维护“最后活跃时间”:
time.Now().Sub(lastActive) > 45s,主动关闭 Conn操作系统级的 keepalive 可作为补充,但不能替代应用层心跳(因默认周期长、不可控):
onn 后,调用 conn.(*net.TCPConn).SetKeepAlive(true)
心跳失败不是终点,而是触发恢复流程的信号:
不复杂但容易忽略:心跳包尽量用固定长度、无编解码开销的原始字节;避免在心跳 goroutine 中执行耗时操作;所有 SetDeadline 必须配对使用,防止后续读写意外阻塞。