当前位置: 首页 > news >正文

最佳实践:Websocket 长连接状态如何保持

WebSocket 是一种支持通过单个 TCP 连接进行全双工通信的协议,相较于传统的 HTTP 协议,它更适合需要实时交互的应用场景。此协议在现代 Web 应用中扮演着至关重要的角色,尤其是在需要实时更新和通信的场合下维持持久连接。本文将探讨 WebSocket 如何有效地维护这些连接,并通过详尽的教程与示例指导开发者更深入地理解与应用此技术。

image.png

应用场景

WebSocket 的持久连接功能在多种应用场景下发挥重要作用,包括但不限于:

  • 即时通讯软件
  • 实时协作编辑工具
  • 多人在线游戏
  • 股票交易平台

在以上场景中运用 WebSocket,可以实现即时数据推送和快速的双向交流,从而大幅提升用户体验。

保持连接的策略

语法概要

通过使用 JavaScript 的 WebSocket API 在客户端和服务器之间建立 WebSocket 连接的过程相当直接。以下是一些基础语法示例:

    // 在客户端建立 WebSocket 连接const socket = new WebSocket('ws://example.com/socket');// 监听接收消息事件socket.addEventListener('message', (event) => {console.log('收到消息:', event.data);});// 发送消息socket.send('您好,服务器!');
策略 1:实行心跳机制

在 WebSocket 中,一种保持连接活跃的常见方法是定期向服务器发送心跳消息。以下是心跳机制的一个代码示例:

    // 定期发送心跳消息setInterval(() => {if (socket.readyState === WebSocket.OPEN) {socket.send('心跳');}}, 30000); // 每30秒发送一次
策略 2:使用 WebSocket 拦截器

WebSocket 拦截器能够在连接的不同阶段加入自定义逻辑。这种方式使得在处理连接建立、消息接收等事件时更加灵活。

    // WebSocket 连接打开拦截器socket.addEventListener('open', (event) => {console.log('连接已建立');// 在此处添加自定义逻辑});socket.addEventListener('message', (event) => {console.log('收到消息:', event.data);// 在此处添加自定义处理逻辑});

WebSocket 实施步骤

步骤 1:建立 WebSocket 连接

首先,需要在你的项目中建立 WebSocket 连接:

    const socket = new WebSocket('ws://example.com/socket');
步骤 2:实施心跳机制

在客户端实施心跳机制,定期向服务器发送心跳消息以保持连接活跃:

    setInterval(() => {if (socket.readyState === WebSocket.OPEN) {socket.send('心跳');}}, 30000);
步骤 3:服务器端心跳处理

服务器端需要相应地处理接收到的心跳消息,以保持连接的活跃状态:

    // 服务器端心跳处理socket.on('message', (data) => {if (data === '心跳') {socket.send('心跳确认');}});

实用提示与注意事项

  • 定期检查连接状态以确保其活跃。
  • 合理安排心跳间隔时间,以避免产生不必要的网络流量。
  • 在连接断开或遇到异常时,应采取措施实现自动重新连接。

如何调试 WebSocket

如果你打算调试 WebSocket 接口,首先需要在 Apifox 中创建一个新的 HTTP 项目,然后向项目中添加 WebSocket 接口。

image.png

输入 WebSocket 服务器的 URL,例如 ws://localhost:3000,保存并命名接口。

image.png

通过选择“消息选项”并输入消息内容,你可以直接发送消息并实时看到服务器和其他客户端的响应。

image.png

以下用 Node.js 写的 WebSocket 服务端和客户端均收到了消息。

image.png

总结

WebSocket 的持久连接能力为实时通信提供了坚实的技术基础,为现代 Web 应用的开发开辟了更多可能性。本文讨论的应用策略对于开发人员来说至关重要,以期优化他们项目中的实时交互体验。

参考链接

  • MDN Web Docs - WebSocket
  • WebSocket: A Guide
  • WebSocket - Wikipedia

相关文章:

最佳实践:Websocket 长连接状态如何保持

WebSocket 是一种支持通过单个 TCP 连接进行全双工通信的协议,相较于传统的 HTTP 协议,它更适合需要实时交互的应用场景。此协议在现代 Web 应用中扮演着至关重要的角色,尤其是在需要实时更新和通信的场合下维持持久连接。本文将探讨 WebSock…...

Unity AStar寻路算法与导航

在游戏开发中,寻路算法是一个非常重要的部分,它决定了游戏中角色的移动路径。Unity作为一款流行的游戏开发引擎,提供了许多内置的寻路算法,其中最常用的就是AStar算法。AStar算法是一种基于图的搜索算法,通过启发式搜索…...

JavaScript最新实现城市级联操作,json格式的数据

前置知识&#xff1a; <button onclick"doSelect()">操作下拉列表</button><hr>学历&#xff1a;<select id"degree"><option value"0">--请选择学历--</option><option value"1">专科<…...

SD NAND:为车载显示器注入智能与安全的心脏

SD NAND 在车载显示器的应用 在车载显示器上&#xff0c;SD NAND&#xff08;Secure Digital NAND&#xff09;可以有多种应用&#xff0c;其中一些可能包括&#xff1a; 导航数据存储&#xff1a; SD NAND 可以用于存储地图数据、导航软件以及车载系统的相关信息。这有助于提…...

矩阵的对角化

概述 对角化矩阵是线性代数中的一个重要概念&#xff0c;它涉及将一个方阵转换成一个对角阵&#xff0c;这个对角阵与原矩阵相似&#xff0c;其主要对角线上的元素为原矩阵的特征值。这样的转换简化了很多数学问题&#xff0c;特别是线性动力系统的求解和矩阵的幂运算。下面是…...

React编写组件时,如何省略.tsx后缀

省略.tsx后缀 当tsconfig.json配置了&#xff0c;需要重启后才会生效 {"compilerOptions": {"allowJs": true,"jsx": "react-jsx",} }当进行以上配置后&#xff0c;导入组件时添加后缀&#xff0c;Eslint报错如下&#xff1a; An im…...

移动端的React项目中如何配置自适应和px转rem

创建项目 create-react-app project-name 启动项目 npm start 下载自适应和px转rem的插件 自适应的&#xff1a; npm install lib-flexible --save px转rem的&#xff1a;npm install postcss-pxtorem5.1.1 --save-dev 创建craco.config.js配置文件 在package.json中…...

TypeScript 结合 React 开发时候 , React.FunctionComponent 解释

在 TypeScript 结合 React 开发时&#xff0c;React.FC&#xff08;或 React.FunctionComponent&#xff09;是一个泛型类型&#xff0c;它用于定义函数组件的类型。这个类型定义了函数组件的结构和预期行为&#xff0c;并且提供了泛型支持&#xff0c;以便你可以指定组件 prop…...

2280. 最优标号(最小割,位运算)#困难,想不到

活动 - AcWing 给定一个无向图 G(V,E)&#xff0c;每个顶点都有一个标号&#xff0c;它是一个 [0,2^31−1] 内的整数。 不同的顶点可能会有相同的标号。 对每条边 (u,v)&#xff0c;我们定义其费用 cost(u,v) 为 u 的标号与 v 的标号的异或值。 现在我们知道一些顶点的标号…...

RestTemplate启动问题解决

⭐ 作者简介&#xff1a;码上言 ⭐ 代表教程&#xff1a;Spring Boot vue-element 开发个人博客项目实战教程 ⭐专栏内容&#xff1a;个人博客系统 ⭐我的文档网站&#xff1a;http://xyhwh-nav.cn/ RestTemplate启动问题解决 问题&#xff1a;在SpringCloud架构项目中配…...

Docker部署前后端服务示例

使用Docker部署js前端 1.创建Dockerfile 在项目跟目录下创建Dockerfile文件&#xff1a; # 使用nginx作为基础镜像 FROM nginx:1.19.1# 指定工作空间 WORKDIR /data/web# 将 yarn build 打包后的build文件夹添加到工作空间 ADD build build# 将项目必要文件添加到工作空间&a…...

方格分割644--2017蓝桥杯

1.用dfs解决&#xff0c;首先这题的方格图形就很像一个走迷宫的类型&#xff0c;迷宫想到dfs&#xff0c;最中心点视为起点&#xff0c;起点有两个小人在这个方格里面对称行动&#xff0c;直到走出迷宫&#xff08;一个人走出来了另一个人就也走出来了&#xff0c;而走过的点会…...

接口测试用例设计注意点

API接口测试&#xff1a; 1>根据接口文档&#xff0c;检查接口调用方法post/get&#xff0c;状态码、请求值、返回值 2>对请求参数做容错、边界值、等价类校验 3>功能可用&#xff0c;用户友好 4>密码加密&#xff0c;http明文&#xff0c;https协议密文 5>业务…...

学习linux从0到工程师(命令)-4

基本命令 uname -m 显示机器的处理器架构 uname -r 显示正在使用的内核版本 dmidecode -q 显示硬件系统部件 (SMBIOS / DMI) hdparm -i /dev/hda 罗列一个磁盘的架构特性 hdparm -tT /dev/sda 在磁盘上执行测试性读取操作系统信息 arch 显示机器的处理器架构 uname -m 显示机器…...

【树莓派系统配置+python3.8+环境配置踩坑点汇总】raspberrypi

最近又开始搞树莓派的深度学习模型。很多windows端的环境需要在树莓派上重新部署&#xff0c;中间出现了非常多的问题。主要以各种库的下载安装为主要。 首先&#xff0c;第一个问题&#xff1a; 树莓派系统烧录之后&#xff0c;默认apt一般需要升级看&#xff0c;而默认下载…...

CTFHUB--文件包含漏洞--RCE

文件包含漏洞 文件包含漏洞也是一种注入型漏洞&#xff0c;其本质就是输入一段用户能够控制的脚本或者代码&#xff0c;并让服务端执行。有时候由于网站功能需求&#xff0c;会让前端用户选择要包含的文件&#xff0c;而开发人员又没有对要包含的文件进行安全考虑&#xff0c;…...

Android 解决引入的三方库中类名冲突问题

参考&#xff1a; Android开发——如何解决三方库中的类名冲突问题_android 类冲突-CSDN博客 Android 解决 jar/aar 包类名冲突 - 简书 实操步骤 1.提前安装好unzip-5.51-bin&#xff0c;proguard-7.4.0&#xff0c;jarjar-1.4软件 2.解压包名冲突的 AAR 文件 进入到需要修…...

扩展学习|大数据分析的现状和分类

文献来源&#xff1a;[1] Mohamed A , Najafabadi M K , Wah Y B ,et al.The state of the art and taxonomy of big data analytics: view from new big data framework[J].Artificial Intelligence Review: An International Science and Engineering Journal, 2020(2):53. 下…...

java学习笔记-初级

完整笔记下载链接&#xff1a;https://download.csdn.net/download/qq_48257021/88800766?spm1001.2014.3001.5503 一、变量 1.双标签 <!-- 外部js script 双标签 --><script srcmy.js></script> 在新文件my.js里面写&#xff1a; 2.字符串定义&#xff…...

使用axios 封装大文件上传,支持断点续传的功能

使用 Axios 实现断点续传、重试、暂停、开始和上传进度功能 简介 在许多应用程序中&#xff0c;我们经常需要上传大文件。但是&#xff0c;由于网络连接不稳定或其他原因&#xff0c;上传过程可能会中断。为了解决这个问题&#xff0c;我们可以使用断点续传功能。断点续传允许…...

无需代码!用圣女司幼幽-造相Z-Turbo轻松生成动漫女神图片

无需代码&#xff01;用圣女司幼幽-造相Z-Turbo轻松生成动漫女神图片 1. 引言&#xff1a;零门槛AI绘画体验 想象一下&#xff0c;只需输入简单的文字描述&#xff0c;就能生成精美的动漫女神图片——这就是圣女司幼幽-造相Z-Turbo带来的神奇体验。这个基于Xinference部署的文…...

深度解密douyin-downloader:高性能抖音无水印下载器的技术实现与实战进阶

深度解密douyin-downloader&#xff1a;高性能抖音无水印下载器的技术实现与实战进阶 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and brow…...

8大网盘直链解析工具:告别下载限速,实现本地高速下载

8大网盘直链解析工具&#xff1a;告别下载限速&#xff0c;实现本地高速下载 【免费下载链接】Online-disk-direct-link-download-assistant 一个基于 JavaScript 的网盘文件下载地址获取工具。基于【网盘直链下载助手】修改 &#xff0c;支持 百度网盘 / 阿里云盘 / 中国移动云…...

告别环境冲突:手把手教你为Flutter 3.7.12与HarmonyOS NEXT搭建纯净的Windows开发环境

告别环境冲突&#xff1a;手把手教你为Flutter 3.7.12与HarmonyOS NEXT搭建纯净的Windows开发环境 在跨平台开发领域&#xff0c;Flutter与HarmonyOS的结合为开发者带来了全新的可能性。然而&#xff0c;当我们需要在已有Android/iOS开发环境的基础上新增鸿蒙支持时&#xff0…...

SDMatte提示词工程指南:编写精准Prompt提升复杂图像抠图质量

SDMatte提示词工程指南&#xff1a;编写精准Prompt提升复杂图像抠图质量 1. 为什么需要关注提示词工程 在图像处理领域&#xff0c;抠图一直是个技术难题。传统方法需要手动绘制选区&#xff0c;费时费力。现在有了SDMatte这样的AI工具&#xff0c;我们可以通过简单的文字描述…...

WeKnora在教育培训场景的应用:构建智能学习助手

WeKnora在教育培训场景的应用&#xff1a;构建智能学习助手 1. 引言 想象一下这样的场景&#xff1a;一位编程老师每天需要回答学生提出的上百个问题&#xff0c;从基础语法到复杂算法&#xff0c;每个问题都需要查阅不同的教材和讲义。或者一位语言学习者&#xff0c;面对厚…...

RexUniNLU实战体验:跟着做,轻松实现电商评论的属性情感自动分析

RexUniNLU实战体验&#xff1a;跟着做&#xff0c;轻松实现电商评论的属性情感自动分析 1. 电商评论分析的痛点与解决方案 电商平台每天产生海量用户评论&#xff0c;这些非结构化文本蕴含着宝贵的用户反馈。传统人工分析方法效率低下&#xff0c;而常规NLP方案又面临两个主要…...

基于2自由度1 4悬架模型的模糊PID控制主动悬架模型及效果对比研究

模糊PID控制主动悬架模型 基于2自由度1/4悬架模型&#xff0c;模糊PID可以自适应调整PID控制的系数&#xff0c;实现更好的控制效果 Simulink模型中对比了被动悬架、PID控制和模糊PID控制主动悬架效果 如图为车身加速度、悬架动挠度和轮胎动载荷的对比结果 &#xff08;包括被动…...

Pixel Aurora Engine实战教程:生成可导入Aseprite的像素图层文件

Pixel Aurora Engine实战教程&#xff1a;生成可导入Aseprite的像素图层文件 1. 教程概述 Pixel Aurora Engine是一款专为像素艺术创作设计的AI工具&#xff0c;它能将文字描述转化为高质量的像素艺术作品。本教程将重点介绍如何生成可直接导入Aseprite&#xff08;流行的像素…...

Z-Image-Turbo-rinaiqiao-huiyewunv 结合STM32:嵌入式设备上的轻量级AI视觉原型

Z-Image-Turbo-rinaiqiao-huiyewunv 结合STM32&#xff1a;嵌入式设备上的轻量级AI视觉原型 1. 引言 你有没有想过&#xff0c;给一块小小的单片机装上“眼睛”&#xff0c;让它能看懂周围的世界&#xff1f;比如&#xff0c;让一个智能花盆识别植物是否缺水&#xff0c;或者…...