我是靠谱客的博主 聪明招牌,最近开发中收集的这篇文章主要介绍关于WebSocket的心跳重连机制(详解),觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

前言

遇到的问题:
实时聊天过程中,
1、websocket连接后,长时间远端和客户端不发消息,服务端会把websocket给断开;
2、所以就需要一种机制来检测客户端和服务端是否处于正常的链接状态。
3、因此就有了websocket的‘心跳监测’。
4、还有心跳,说明还活着,没有心跳说明已经断开了。

websocket基础使用

基础使用

心跳机制

1、心跳机制是每隔一段时间会向服务器发送一个数据包:
	告诉服务器(后台)自己还活着,同时客户端(浏览器)会确认服务器端是否还活着
2、如果还活着的话,就会回传一个数据包给客户端
3、服务端断开连接了。客户端需要重连~

实现:

  1. 初始化建立websocket连接,websocket监听事件
init(row) {
    this.connectSocket() // 建立websocket连接
    this.socket.onopen = (e) => {
        console.log('Connection to server opened');
        // 连接成功执行的逻辑
    }
    // websocket连接接收消息后监听事件
    this.socket.onmessage = async(msg) => {
        try {
            var data = JSON.parse(msg.data)
            console.log(data)
        } catch(err){
            return
        }
        // websocket连接接收消息处理逻辑
    }
},
// 连接websocket
        connectSocket() {
            var address = window.location.hostname
            var protocol = 'ws'
            if (location.protocol === 'https:') {
                protocol = 'wss'
            }
            var url = ''
            url = protocol+'://'+location.host+`proxy代理字段`+'/websocket/'+`后台所需参数` 
            this.socket = this.createWebSocket(url)
            // 监听连接失败
            this.socket.onerror = this.websocketonerror
            // 监听连接关闭
            this.socket.onclose = this.websocketclose
        },
websocketonerror () { // 监听连接失败
            console.log('websocket连接断开')
            this.connectSocket()
          },
 websocketclose (e) { // 监听连接
     console.log('断开连接', e)
     this.connectSocket() // websocket关闭链接重连
 },

 // 创建websocket对象
 createWebSocket(url) {
     console.log(url)
     try{
         if(window.WebSocket)
             return new WebSocket(url);
         if(window.MozWebSocket)
             return new MozWebSocket(url);
     } catch(e) {
     }
     return false;
 },
  1. 心跳监测
1、什么时候进行心跳监测
2、逻辑代码
3、什么时候重置心跳监测
4、关闭心跳监测

websocket连接成功进行监测心跳

init(row) {
   this.connectSocket()
   this.socket.onopen = (e) => {
       console.log('Connection to server opened');
++    this.longstart();   // 成功建立连接后,创建心跳检测
       // 连接成功执行的逻辑
   }
   this.socket.onmessage = async(msg) => {
       try {
           var data = JSON.parse(msg.data)
           console.log(data)
       } catch(err){
           return
       }
       // websocket连接接收消息处理
   }
},

接收消息后进行心跳重置

 init(row) {
    this.connectSocket()
    this.socket.onopen = (e) => {
        console.log('Connection to server opened');
	    this.longstart();   // 成功建立连接后,创建心跳检测
        // 连接成功执行的逻辑
    }
    this.socket.onmessage = async(msg) => {
++    	console.log('心跳重置')
++        this.longstart();
        try {
            var data = JSON.parse(msg.data)
            console.log(data)
        } catch(err){
            return
        }
        // websocket连接接收消息处理
    }
},

逻辑代码-所需数据

data(){
	return {
		timeoutObj:undefined,
       serverTimeoutObj:undefined,
       socket:undefined
	}
}
longstart() {
			//1、通过关闭定时器和倒计时进行重置心跳
           clearInterval(this.timeoutObj)
           clearTimeout(this.serverTimeoutObj);
           // 2、每隔30s向后端发送一条商议好的数据
           this.timeoutObj = setInterval(()=>{
               console.log('重置监测心跳')
               let data={ // 与后端商量好心跳要传递的值
                   content: "pong",
                   contentType: "hert"
               }
               this.socket.send(JSON.stringify(data))
               // 3、发送数据 2s后没有接收到返回的数据进行关闭websocket重连
               this.serverTimeoutObj = setTimeout(()=>{
                   console.log("后台挂掉,没有心跳了....");
                   console.log("打印websocket的地址:"+this.socket);
                   this.socket.close();
               }, 2000);
           },30000)
         },

关闭心跳机制

destroyed () {
       // 1、组件销毁时,关闭与服务器的连接
       if (this.socket) {
         this.socket.close() // 离开路由之后断开websocket连接
       }
       // 2、通过关闭计时器和倒计时关闭心跳监测
       clearInterval(this.timeoutObj)
       clearTimeout(this.serverTimeoutObj);
     },
注意事项
1、 由于我们的websocket连接关闭立即进行重连了,组件销毁时,
断开websocket连接又走了重连机制
2、 websocketclose (e) { // 关闭
     this.connectSocket()
},
3、 所以我们需要定义一个变量控制是组件销毁关闭的websocket
还是心跳监测重连时关闭的websocket

定义变量判断是组件销毁关闭的websocket,还是心跳监测重连时关闭的websocket

data(){
       return{
       		~~~~
++           lockReconnect:false // 为true时,是心跳重连的websocket断开连接
       }
   },
destroyed () {
       this.lockReconnect=false
       // 组件销毁时,关闭与服务器的连接
       if (this.socket) {
         this.socket.close() // 离开路由之后断开websocket连接
       }
       clearInterval(this.timeoutObj)
       clearTimeout(this.serverTimeoutObj);
     },
longstart() {
            clearInterval(this.timeoutObj)
            clearTimeout(this.serverTimeoutObj);
            // clearInterval(this.overTime)
            this.timeoutObj = setInterval(()=>{
                console.log('重置监测心跳')
                let data={
                    chatType:"hert",
                    receiverId: this.chatroomList.userId,
                    receiverName: this.chatroomList.userName,
                    senderAvatar: this.userInfo.avatar,
                    senderName: this.userInfo.userName,
                    content: "pong",
                    contentType: "hert"
                }
                this.socket.send(JSON.stringify(data))
                this.serverTimeoutObj = setTimeout(()=>{
 ++                   this.lockReconnect=true // 心跳重连设置为true
                    console.log("后台挂掉,没有心跳了....");
                    console.log("打印websocket的地址:"+this.socket);
                    this.socket.close();
                    // createWebSocket();
                }, 2000);
            },30000)
            // },110000)
          },
websocketclose (e) { // 关闭
    console.log('断开连接', e)
    //lockReconnect为true在进行重连
++     if(this.lockReconnect){
++         this.connectSocket()
++     }else{
++     }
 },

最后

以上就是聪明招牌为你收集整理的关于WebSocket的心跳重连机制(详解)的全部内容,希望文章能够帮你解决关于WebSocket的心跳重连机制(详解)所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(82)

评论列表共有 0 条评论

立即
投稿
返回
顶部