WebSocket 客户端连接不上和掉线的问题以及解决方案

2018-07-18 16:33:57 +08:00
 jonychen1

看到最近有很多人在 blog 上问关于 WebSocket 客户端连接和掉线的问题,有一部分我以前也遇到过,在这里我罗列了一些我以前遇到过的问题和其他简单的 WebSocket 服务。

Q1 客户端连接不上的问题 这个问题我遇到的基本集中在后端,遇到的话需要收集日志进行分析,首先要查看是因为什么原因出现问题的,不过这种情况下多半会出现 Exception,从 Exception 着手分析问题即可。

Q2 1 客户端掉线问题 这里所指的客户端掉线的问题是指客户端非正常掉线。有的时候会出现 Exception,通过处理 Exception 即可关闭连接,有的时候像客户端突然网络离线的情况下,这个时候后台没有收到客户端发来的 close frame,会认为这个客户端还是处在在线的情况。那这个问题可以通过心跳包的问题解决。也可以通过客户端向服务器发心跳包,也可以服务器发送心跳包至客户端。我们最终采用的方案是客户端向服务端发送心跳包,服务端收到心跳包后会检测当前 websocket session 队列中是否存在同属性的 websocket session,有的话关闭以前的 session 即可。我个人认为还是服务端像客户端发送心跳包好一些,但这样做要注意性能问题。

Q3 websocket 连接后 1 分钟自动断开关闭 这是因为 websocket 长连接有默认的超时时间( 1 分钟,由 proxy_read_timeout 决定),就是超过一定的时间没有发送任何消息,连接会自动断开。解决办法就是让浏览器每隔一定时间(要小于超时时间)发送一个心跳。代码如下: window.setInterval(function(){ //每隔 5 秒钟发送一次心跳,避免 websocket 连接因超时而自动断开 var ping = {"type":"ping"}; ws.send(JSON.stringify(ping)); },5000);

Q4 能收到客户端消息,后台也显示发送,但是客户端收不到 这个问题经我个人观察和猜测,应该是 websocketsession 没有成功关闭或者成功关闭但是和一个 websocketsession 对应多个 session 有关,因为我把上面的问题解决了之后,这个问题也没出现过了。

最近因为工作需求较多,又有新项目要进来,项目周期太紧了,经过团队商量,自己开发 WebSocket 这一块,要做稳定成本太高了,所以我们决定使用第三方的 WebSocket 服务,经过我们对比多个第三方服务,最终发现了一个 Java websocket 神器叫 GoEasy,相比较其他的三方,我觉得这个上手更加简单,对各种浏览器的兼容也非常好。用到现在也没有什么问题,你们有兴趣的可以去试一下。 网址: http://www.goeasy.io 希望我遇到的问题以及解决方案对你们有所帮助。

1521 次点击
所在节点   2018
1 条回复
ookkxw
2018-07-18 16:42:01 +08:00
mark 有空看

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/472034

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX