我们有一个 SPA,它在客户端和服务器 (NodeJs) 端运行 SockJs。对于 Windows 工作站,我们可以毫无问题地维护与部署在 Windows Azure 中的服务器的 Web 套接字连接。但对于一些使用 Mac OS X 工作站的同事来说,他们在最近几周遇到了 Web 套接字频繁随机断开连接的情况。发生在 Chrome 或 Firefox 上,因此它似乎处于较低的操作系统级别。
据他们所知,没有可能影响网络堆栈的 OS X 更新。似乎也没有在 SockJs 上发现任何问题。OS X 的任何故障排除技巧?
所以我设法借了我同事的一台 Macbook,并在上面安装了 Wireshark。
监控 HTTP 流量,我看到预期的 websocket 升级交换正在发生,然后,我注意到从服务器发送的 TCP 级别 RST 重置数据包。之后,客户端工作站必须重新启动一个全新的 HTTP 连接和 websocket 升级。最终在服务器的另一个 RST 中结束。
在尝试比较我的 Windows 工作站上的情况时,我发现网络堆栈每 3-5 秒自动向服务器发送 keep-alive ACK 数据包。看起来 Mac OS 网络堆栈没有意识到现有的 HTTP 连接已经升级到 websocket,因此不会费心传递必要的 ACK 数据包来通知服务器它仍然存在。
为了在 Mac 上解决这个问题,我们编写了客户端以定期发送“ping”数据以保持 websocket 连接。