文档章节

websocket 心跳包重连

i5--lou
 i5--lou
发布于 2016/03/11 10:35
字数 689
阅读 6322
收藏 7

上次我们讲过了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);

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

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

© 著作权归作者所有

共有 人打赏支持
i5--lou
粉丝 19
博文 72
码字总数 33811
作品 0
杭州
程序员
私信 提问
加载中

评论(4)

i5--lou
i5--lou

引用来自“supermap_fly”的评论

能给个完整的例子吗?有些地方看不太懂啊

哪里写的不明白吗0
supermap_fly
supermap_fly
能给个完整的例子吗?有些地方看不太懂啊
supermap_fly
supermap_fly
能给个完整的例子吗?有些地方看不太懂啊
supermap_fly
supermap_fly
能给个完整的例子吗?有些地方看不太懂啊
websocket-heartbeat-js心跳检测库正式发布

前言: 两年前写了一篇websocket心跳的博客——初探和实现websocket心跳重连。 阅读量一直比较大,加上最近考虑写一个自己的npm包,因此就完成了一个websocket心跳的检测库。在这里先感谢几个...

10/15
0
0
微信小程序实现WebSocket心跳重连

最近在开发小程序用到了WebSocket,小程序提供了相应的原生API,与H5的API使用方式上有一些区别,所以流行的H5的一些成熟的类库使用起来有些困难,而原生API又存在一些缺陷,所以就自己实现了...

白伟业
07/30
0
0
WebSoket初探并于SpringBoot整合

版权声明:本文版权归Jitwxs所有,欢迎转载,但未经作者同意必须保留原文链接。 https://blog.csdn.net/yuanlaijike/article/details/83002143 一、WebSocket 1.1 HTTP与WebSocket WebSocket...

Jitwxs
10/10
0
0
talent-tan/tio-websocket-showcase

tio-websocket-showcase 项目介绍 展示tio-websocket的用法,官方提供的唯一tio-websocket示范教程 包括wss和流量监控及处理等高级特性 还包括t-io作者写的一个用于连接websocket服务器的js小...

talent-tan
05/06
0
0
手摸手教你使用WebSocket[其实WebSocket也不难]

前言 在本篇文章之前,很多人听说过,没见过,没用过,以为是个很高大上的技术,实际上这个技术并不神秘,可以说是个很容易就能掌握的技术,希望在看完本文之后,马上把文中的栗子拿出来自己...

OBKoro1
10/29
0
0

没有更多内容

加载失败,请刷新页面

加载更多

MYSQL事务处理

INNODB 事务里,所有表引擎必须为INNODB,在非实务表上操作,不会警告,不会报错,但没有效果

关元
15分钟前
1
0
cmake 编译脚本

#!/bin/sh test -d build || mkdir -p build cd build cmake .. make

shzwork
33分钟前
2
0
从零开始实现Vue简单的Toast插件

概述: 在前端项目中,有时会需要通知、提示一些信息给用户,尤其是在后台系统中,操作的正确与否,都需要给与用户一些信息。 1. 实例 在Vue组件的methods内,调用如下代码 `this``.$toast({...

前端小攻略
38分钟前
1
0
yaf和yaconf

pecl install yafpecl install yaconf [yaf] yaf.environ = dev yaf.use_spl_autoload = On yaf.use_namespace = 1 [yaconf] yaconf.directory = /data/wwwroot/yaconf......

果树啊
38分钟前
0
0
day01:shell基础(shell基础、alias及重定向)

1、shell基础介绍: shell是一个命令解释器,用于用户与机器的交互: 也支持特定的语法(逻辑判断,循环): 每个用户都有自己特定的shell:Centos7的shell是bash(bourne agin shell): shel...

芬野de博客
41分钟前
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部