IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 网络协议 -> websocket完成心跳功能的完整版 -> 正文阅读

[网络协议]websocket完成心跳功能的完整版

这是对以前一篇文章的升级迭代版。因为需求有所改动就做了很多的优化。
话不多说直接上代码:

1:因为要做到心跳时间可配置,就写了个txt,运维人员可以修改

这里关注heart_time就行了
这里关注heart_time就行了

2:ajax去读取时间,调用心跳函数

 ngOnInit(): void {
        // 避免重复创建就用变量存到了session
        if(!sessionStorage.getItem('heart')){
            // 请求心跳 读取配置数,默认10秒
            let n = 10;
            const that = this;
            sessionStorage.setItem('heart','true');
            $.ajax({
                type: 'GET',
                url: 'download.txt',
                dataType: 'json',
                success: function(data){
                   n = parseInt(data.heart_time,10)*1000;
                   // 调用心跳函数
                   that.setHeartWs(n);
                },
                error: function(e){
                    that.msg.warning('未知错误,请联系管理员');
                }
            })
        }
        // 因为刷新页面会关闭websocket,就在刷新前删除session,这样可以重新建立心跳
        window.onbeforeunload = function(){
            sessionStorage.removeItem('heart');
        }
        }
        
       

3:重点来了,心跳函数

setHeartWs(n:number){
        const that = this;
        const token_:any = this.tokenService.getPayload();
        let message = `${token_.userId}_${token_.clientIp}`;
        let lockReconnect = false; // 避免重复连接
        let protocol: any;
        if (window.location.protocol === 'http:') {
            protocol = window.location.protocol.replace('http', 'ws');
        } else if (window.location.protocol === 'https:') {
            protocol = window.location.protocol.replace('https', 'wss');
        }
        const host = window.location.host;
        const path = 'ping';

        let ws:WebSocket;
       
        let tt = 0;
        // 创建ws
        function creatWs(){
            try{
                ws = new WebSocket(`${protocol}//${host}/${path}`);
                init();
            }catch(e){
                reconnect();
            }
        }
        // 初始化
        function init(){
            ws.onopen = function(){
                ws.send(message);
                // 心跳检测重置
                heartCheck.start();
            };
            ws.onmessage = function(event){
                // 心跳检测重置
                heartCheck.start();
            }
            ws.onerror = function(event){
                // 心跳检测重置
                heartCheck.start();
            }
            // 监听关闭
            ws.onclose = function(event){
                // 如果不是授权超时,就重连
                if(sessionStorage.getItem('heart')){
                    heartCheck.start();
                }
            }
        }

        // 重新连接
        function reconnect() {
            if(lockReconnect) {
                return;
            };
            lockReconnect = true;
            //没连接上会一直重连,设置延迟避免请求过多
            tt && clearTimeout(tt);
            tt = setTimeout(function () {
                creatWs();
                lockReconnect = false;
            }, n);
        }

        //心跳检测
        var heartCheck = {
            timeout: n,
            timeoutObj: null,
            serverTimeoutObj: null,
            start: function(){
                const that = this;
                that.timeoutObj && clearTimeout(that.timeoutObj);
                that.serverTimeoutObj && clearTimeout(that.serverTimeoutObj);
                // 判断是不是授权超时
                if(sessionStorage.getItem('heart')){
                    that.timeoutObj = setTimeout(function(){
                       //这里发送一个心跳,后端收到后,返回一个心跳消息
                       if(ws&&ws.readyState<3){
                        ws.send(message);
                        }else{
                            // 个别服务需要重启,ws重连
                            lockReconnect = false;
                            reconnect();
                        }
                    }, that.timeout)
                }
            }
        }
        creatWs();
    }

这样基本上就可以满足项目里心跳功能的实现了。
工作上的总结,能有所帮助就最好了。
如果有什么问题,欢迎留言交流。

  网络协议 最新文章
使用Easyswoole 搭建简单的Websoket服务
常见的数据通信方式有哪些?
Openssl 1024bit RSA算法---公私钥获取和处
HTTPS协议的密钥交换流程
《小白WEB安全入门》03. 漏洞篇
HttpRunner4.x 安装与使用
2021-07-04
手写RPC学习笔记
K8S高可用版本部署
mySQL计算IP地址范围
上一篇文章      下一篇文章      查看所有文章
加:2021-08-11 12:47:32  更:2021-08-11 12:47:50 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/25 19:32:39-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码