golang如何实现WebSocket断线重连_golang WebSocket断线重连实现要点

WebSocket断开后ReadMessage()立即返回错误而非重试,需显式判断关闭原因并用退避策略重连,同时分离读写逻辑、管理发送队列与心跳定时器。WebSocket连接断开后,conn.ReadMessage() 会直接报错Go 的 gorilla/websocket 库中,一旦底层 TCP 连接断开(比如网络抖动、服务端重启、NAT 超时),conn.ReadMessage() 不会阻塞等待,而是立即返回 *websocket.CloseError 或 io.EOF。很多人误以为它会"自动重试",其实不会------它只是读操作,不负责连接生命周期管理。常见错误现象:? 程序静默退出读循环,不再收消息? 没有触发重连,客户端彻底失联? 日志里反复出现 read tcp: use of closed network connection必须在 ReadMessage() 的 error 分支里显式判断是否为连接已断(如 websocket.IsUnexpectedCloseError(err, websocket.CloseGoingAway))不要只检查 err != nil 就 panic 或 return,要区分临时错误(如 net.OpError)和永久断连读循环外层建议用 for + select 控制,避免 goroutine 泄漏重连逻辑不能写在 ReadMessage() 错误处理里硬循环如果在读失败后直接 while(true) { dial(); time.Sleep() },容易卡死 goroutine、耗尽资源,还可能掩盖真实错误(比如证书过期、域名解析失败)。正确做法是把重连抽成独立控制流,和读/写解耦:立即学习"go语言免费学习笔记(深入)";用一个单独的 goroutine 管理连接状态,监听 ctx.Done() 或自定义的 reconnectCh每次重连前加退避(backoff),比如从 100ms 开始,指数增长到最大 30s,避免雪崩式重连重连成功后,重新启动读/写 goroutine,并同步重置心跳计时器(否则旧 timer 可能还在往已关闭的 conn 写 ping)务必在重连前调用 conn.Close(),否则旧连接 fd 不释放,Linux 下很快 hit ulimitwebsocket.DefaultDialer 缺省配置不支持长连接保活默认 dialer 不设 Proxy、TLSClientConfig、HandshakeTimeout,更关键的是没配 KeepAlive 和 WriteDeadline,导致 NAT 中间件(如家用路由器、云厂商 LB)在 60s 左右静默 kill 连接。 Tellers AI Tellers是一款自动视频编辑工具,可以将文本、文章或故事转换为视频。

相关推荐
ZeroNews内网穿透2 小时前
ZeroNews安全网关接入企业微信自建应用
网络·数据库·安全·云计算
云和数据.ChenGuang2 小时前
机器学习之方差和标准差计算
人工智能·python·机器学习·django·pygame·deepseek
数据雕塑家2 小时前
数据库 + Grafana 可视化配置指南:从数据源连接到第一个仪表盘
数据库·grafana
岁岁的O泡奶2 小时前
ctfshow_crypto_萌新赛
经验分享·python·密码学·crypto
YuanDaima20482 小时前
队列与单调队列基础原理与题目说明
人工智能·python·算法·leetcode·队列·手撕代码
源图客2 小时前
Linux系统部署Postgres数据库(ubuntu22.04)
linux·运维·数据库
minebmw72 小时前
Oracle 19.29 中 ORA-00600 [4000] 错误完全解析
数据库·oracle
编程经验分享2 小时前
Windows 安装 PostgreSQL 并安装 vector 扩展
数据库·postgresql
ZPC82102 小时前
moveit servo 发指令给real arm
java·前端·数据库