线上websocket自动断开解决思路

2020年1月18日22:24:21 发表评论 阅读(4,316)
本文最后更新于2020年1月18日,已超过一年没有更新,如果文章内容或图片资源失效,请留言反馈,我们会及时处理,谢谢!

线上websocket自动断开解决思路

WebSocket是一种网络传输协议,可在单个TCP连接上进行全双工通信,位于OSI模型的应用层。

WebSocket使得客户端和服务器之间的数据交换变得更加简单,允许服务端主动向客户端推送数据。在WebSocket API中,浏览器和服务器只需要完成一次握手,两者之间就可以创建持久性的连接,并进行双向数据传输。                 --维基百科

最近折腾了一下websocket,在本地服务器跑起来一点问题都没有,但是当我把他部署在线上服务器就出现了一些问题。

如题所说,websocket在握手成功后,如果不发消息,过段时间(一般用秒来算)就会自动断开,那么怎么才能不断开呢?网上搜索后发现可以设置一个心跳包,每隔小于断开连接的时间内执行一次,内容主要是给服务端发送一个固定的消息,服务端监听到这个消息后再返回一个自定义的收到消息,这样websocket就不会再自动断开了。

主要步骤:

1、设置一个setTimeout方法,根据情况设置执行时间。

2、在连接成功的onopen回调函数执行这个setTimeout方法。

  1. //定时器方法
  2. function startTimer(){
  3.     timer = setTimeout( function(){
  4.     ws.send('{"type":"heartbeat","content":"ping"}')
  5. },8000)
  6. }

3、接收服务器返回的消息。

线上websocket自动断开解决思路

4、如果服务器返回了消息,就将计时器清空并且重新计时。

 

 

以上。

 

weinxin
微信小程序
互联网开发,终身学习者,欢迎您的关注!
舍得

发表评论

不高兴 彩虹 吃瓜 丢翔 乖 滑稽 花心 惊哭 惊讶 挤眼 酷 伤心 帅吗? 礼物 玫瑰 怒 生气 喷 睡觉 太开心 小九九 啊
太阳 吐舌 委屈 笑眼 星星月亮 心碎 咦 阴险 疑问 真棒 偷笑 斜眼笑 震惊 略 哈欠 无奈哭 抠鼻 哼 期待 懒得理你 爱心 蜡烛