websocket 心跳包重连

三世轮回 提交于 2019-12-07 15:46:27

上次我们讲过了websocket断线重连的问题,那么久会有人提出疑问了,心跳包重连跟断线重连有什么区别呢? 

其实这两个都是为了达到一个目的,那就是保证当前设备的网络状态保持通畅。。。而断线重连呢,只能保证网络失去连接的时候有效,并不能保证网络断开的时候有效。。。这么说可能就有很多人迷糊了,这两者之间有什么区别呢?

其实很简单哈,至少我是这么理解的。网络失去连接的时候是你手动关闭网络或禁用网络时,这个时候会触发到websocket中的onclose事件,也就是说他会触发断线重连,

而网络断开的时候呢,指的是比较简单粗暴的方法,例如直接拔网线之类的。。。。而这个时候呢是不会触发onclose事件的,那这个时候我们要怎么办呢,我们就需要用到心跳重连了

好啦,说了这么多,现在我们直接来看代码吧。。。。

首先是断线重连,这个我们就不说了,如果没明白的可以去看我写的另外一篇关于断线重连的文章,这里我就不多说了。。。。

那么我们重点来讲一下心跳包重连

if (jsonGotData.hasOwnProperty('id')) {
  timestampVal = new Date(jsonGotData.now_time);
  heartbeatLive(webSocket, timestampVal);
}
if (jsonGotData.hasOwnProperty('heartbeat')) {
  timestampVal = new Date(jsonGotData.heartbeat);
  return heartbeatLive(webSocket, timestampVal);
}

这是在onmessage中收到信息时候的处理,那么我们来具体分析

if (jsonGotData.hasOwnProperty('id')) {
  timestampVal = new Date(jsonGotData.now_time);
  heartbeatLive(webSocket, timestampVal);
}

首先这里我们是判断服务端发送的是不是id字段,这使得我们可以来初始化发送时间

if (jsonGotData.hasOwnProperty('heartbeat')) {
  timestampVal = new Date(jsonGotData.heartbeat);
  return heartbeatLive(webSocket, timestampVal);
}

然后是判断服务端有没有发送heartbeat字段来判断是不是在心跳周期之内

OK,那么来看具体的心跳函数

heartbeatLive = (function(_this) {
  return function(conn, nowTime) {
    var nowtime, hbt;
    nowtime = new Date();
    if ((nowTime.add({
      minutes: 1
    })).isBefore(androidNowtime)) {
      clearTimeout(hbt);
      return newConnection();
    }
    return hbt = setTimeout(function() {
      return conn.send('heartbeat');
    }, 60000);
  };
})(this);

这个心跳函数的功能是怎么样的呢,主要的逻辑是将本地的时间与获取到服务器的心跳时间做一个比较,判断我们的心跳阶段是不是处于一个“健康期”,如果存在的话,那自然是继续正常的心跳啦,那如果不正常的话,我们就要来重连了。。。

而我们用这个心跳重连的方法呢,就可以保证某些傻小白把网线给拔了,都不知道问题出在哪里,这样就可以放心地使用我们的消息推送了,哈哈。。。

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!