简单但全面了解一下webSocket

文章目录

  • webSocket是`一种协议`,设计用于提供`低延迟`、`双全工`和`长期运行`的连接
    • 什么是实时通信?
  • webSocket之前的世界
  • webSocket的优势
  • 为什么需要心跳机制?
    • webSocket的限制

webSocket是一种协议,设计用于提供低延迟双全工长期运行的连接

**全双工:**通信的两个参与方可以同时发送和接收数据,不需要等待对方的响应或传输完成。双全工指的是一种通信方式,通过建立全双工的持久连接客户端和服务器之间就能实现高效实时性更强的通信。

什么是实时通信?

传统通信: 电子邮件、网页浏览存在延迟,需要用户主动请求来获取更新数据。
实时通信: 即时消息传递(即时聊天)、音视频通话、在线会议和实时数据传输等,可以实现即时的数据传输和交流,不需要用户主动请求或刷新来获取更新数据。

webSocket之前的世界

在webSocket出现之前实现实时通信主要通过以下几种技术来解决:

  1. 轮询:客户端定期向服务器发送请求,询问是否有新的数据可以用服务器在接收到请求后再检查是否有更新的数据,并将其返回给客户端。
    缺点: 产生大量的请求和响应,导致不必要的网络开销和延迟。
  2. 长轮询: 在客户端发出请求后,服务器会保持连接打开一段时间,等待新数据响应后再关闭连接。是基于HTTP的技术
    优点:解决了无效轮询的数量
    缺点:需要频繁的建立和关闭连接
  3. Comet:Comet和长轮询一样是基于HTTP的技术,和长轮询不同的是它可以在返回请求后在返回请求后继续保持连接打开,它的核心思想就是通过保持长连接来模拟实时通信并允许服务器通过流式传输,iframe等推送技术来 主动向客户端推送数据,不过Comet虽然可以模拟实时通信但是它仍然是基于HTTP的模型,在Comet中服务器推送数据给客户端的方式通常还是通过延长响应或使用推送技巧来实现的。

webSocket的优势

总的来说,webSocket相比起其他的技术,有着以下这些优势:

  1. 双向实时通信
    允许在单个、长时间的连接上进行双向实时通信。需要在快速实时更新的应用程序里,比HTTP更加高效。WebSocket允许服务器主动向客户端推送数据,而不需要客户端发起请求。这种服务器推送的机制可以实现实时更新数据的功能,避免了客户端频繁地发送请求来获取最新数据的需求。

  2. 降低延迟
    webSocket的连接一旦建立便会保持开放,数据可以在客户端和服务器之间比HTTP更低的延迟进行传输。

  3. 更高效的资源利用
    可以减少重复请求和响应的开销,因为它的连接只需要建立一次。WebSocket在通信过程中的头部开销相对较小。HTTP协议每次请求都需要发送完整的头部信息,而WebSocket只需要在建立连接时发送一次头部信息,之后的通信只需要发送数据本身,减少了额外的开销。

  4. 二进制数据支持:
    WebSocket支持传输二进制数据,而HTTP协议主要用于传输文本数据。对于一些需要传输大量二进制数据的应用场景,WebSocket可以更高效地进行数据传输。

(这里补充一下HTTP协议:HTTP是一种无状态的协议,每次请求都需要建立一个新的连接,完成请求后立即关闭连接)
可以说webSocket的出现填补了传统的HTTP协议在实时通信方面的不足,它允许客户端和服务器之间通过单个TCP连接进行双工通信,并且进行实时的数据交换,所以webSocket的协议非常适用于基于Web的游戏、聊天应用以及任何低延迟实时连接的应用程序。目前的webSocket已经得到了主流浏览器的支持,而且由于webSocket的标准定义了一套通信规范,所以无论是JavaScript、Java还是其他编程语言都存在相应的库、框架或者模块来支持WebSocket的实现和使用,比如JS就有Socket.io。

那么要如何建立一个webSocket连接呢?
webSocket的建立需要通过HTTP发送一次常规的Get请求,并且在请求头中带上Upgrade,告诉服务器我想要从HTTP升级为WebSocket连接就建立成功了,之后客户端和服务器双方便可以随时向彼此发送信息。
在这里插入图片描述

在这里插入图片描述
后端部分用的node.js
先是引用了http和webSocket模块,先创建一个http实例,然后通过它再创建webSocket服务器,当有客户端连接到wenSocket服务器时就会触发Connection事件,当从客户端接收到消息时候会触发Message事件会接收一个参数表示从客户端那里接收到的消息内容
在这里插入图片描述

为什么需要心跳机制?

为了保持webSocket稳定的长连接,连接状态可能会因为各种原因发生变化,在连接建立之后,服务器和客户端之间通过心跳包来保持连接状态,以防止连接因为长连接没有数据传输而被切断。
心跳包就i是一种特殊的数据包,不包含任何实际数据,仅用来维持连接状态,通常情况下心跳包由客户端和服务器端定期发送一个空的数据帧,以确保双方的连接仍然有效,避免连接因为长时间没有数据传输而被中断,如果在一段时间内没有收到对方的心跳包就可以认为连接已经断开需要重新建立连接。

为什么发送空的数据帧就可以确保双方连接有效?

  1. 保持连接活跃:WebSocket连接在一段时间内没有数据传输时,可能会由于网络设备的超时机制或其他原因被关闭。通过定期发送空的数据帧,可以向服务器发送一个信号,告知连接仍然活跃,防止连接被关闭。

  2. 检测连接状态:发送心跳包可以帮助检测连接是否正常。如果客户端或服务器在一定时间内没有收到心跳包,就可以判断连接可能已经断开。这样可以及时采取措施,例如重新建立连接或通知用户连接中断。

  3. 节省带宽和资源:发送空的数据帧相比发送实际数据,可以减少数据传输的带宽消耗和服务器资源占用。心跳包通常只包含一些固定的控制信息,不需要传输大量的数据,因此可以降低网络负载和服务器负载。

  4. 快速检测连接中断:由于心跳包是定期发送的,一旦连接中断,客户端或服务器可以迅速发现连接断开的情况。这样可以更快地采取恢复措施,提高连接的可靠性和用户体验。

需要注意的是,心跳包的发送频率应根据具体应用的需求进行调整。发送过于频繁的心跳包可能会增加网络负载,而发送过于稀少的心跳包可能无法及时检测到连接中断。因此,需要根据实际情况选择合适的心跳包频率。

webSocket的限制

  1. 不提供加密功能
    如果有安全上的需求,需采用其他方式来确保安全性,如SSL协议对webSocket连接进行加密,防止敏感信息被窃听或者篡改,另外也可以限制访问的权限,在服务端设置黑名单或者白名单只允许特定IP地址或者域名的客户端进行连接。
  2. 不支持古老的浏览器
    不支持IE10以前的版本。需要使用AJAX或者其他方式来进行替代
  3. 优化很重要
    除此之外,当webSocket连接过多时可能会对服务器的性能造成负面影响,因为webSocket是一个长连接,需要服务器不断的维护和处理连接状态,优化性能。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/640766.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

CRM系统的痛点,如何解决?

在当今竞争激烈的商业世界中,客户关系管理(CRM)数字化转型已经成为大企业成功的重要秘诀。大型跨国公司如亚马逊、苹果和微软等已经在CRM数字化方面走在了前列,实现了高度个性化的客户体验,加强了客户忠诚度。 然而&a…

Conda python管理环境environments 四 从入门到精通

Conda系列: 翻译: Anaconda 与 miniconda的区别Miniconda介绍以及安装Conda python运行的包和环境管理 入门Conda python管理环境environments 一 从入门到精通Conda python管理环境environments 二 从入门到精通Conda python管理环境environments 三 从入门到精通…

【Linux】解决能访问github但克隆不了的问题

文章目录 1.查看你的代理的地址:2.git设置3.尝试clone 1.查看你的代理的地址: 2.git设置 先看看当前的git设置 $ git config --list然后git中要设置好对应的地址 git config --global http.proxy 127.0.0.1:78903.尝试clone $ git clone https://git…

服务器感染了.wis[[Rast@airmail.cc]].wis勒索病毒,如何确保数据文件完整恢复?

导言: 在当今数字化的时代,恶意软件攻击已经变得越来越复杂和狡猾,[[MyFilewaifu.club]].wis [[backupwaifu.club]].wis[[Rastairmail.cc]].wis勒索病毒是其中的一种新威胁。本文91数据恢复将深入介绍[[MyFilewaifu.club]].wis [[backupwaif…

机器学习实验报告-集成学习

目录 一、集成学习介绍 1.1集成学习的引入 1.2集成学习发展史 1.3集成学习的学习组织方式 1.3.1并联组织关系 1.3.2串联组织关系 1.4集成学习及其实现方法概述 二、集成学习实现方法 2.1Boosting 2.1.1基本过程 2.1.2注意点 2.2bagging 2.2.1基本过程 2.2.2注意点…

[SpringBoot2.6.13]FastJsonHttpMessageConverter不生效

文章目录 错误描述问题分析打印目前所有的消息处理器寻找适配版本消息解释器加载顺序 错误原因正确写法使用最新版本fastjson(2024-1-22)配置fastjson2消息转换器(保留系统原消息转换器)替换消息转换器配置fastjson2 错误描述 采用Bean的方式配置FastJsonHttpMessageConverter…

苹果眼镜(Vision Pro)的开发者指南(4)——ARKit插件

该平台运用ARKit算法,处理持久性、世界映射、分割、遮罩和环境照明等功能。这些算法持续运行,使得应用和游戏在共享空间中自动受益于ARKit。一旦应用启动专用的Full Space,它便能利用ARKit API,完美融合虚拟与现实世界。 在此,我们将深入探讨这个框架如何重新定义交互体验…

React16源码: React中的reconcileChildren的源码实现

reconcileChildren 1 )概述 在更新了一个节点之后,拿到它的props.children要根据这个children里面的 ReactElement 来去创建子树的所有的 fiber 对象要根据 props.children 来生成 fiber 子树,然后判断 fiber 对象它是否是可以复用的 因为我…

QT实现USB通讯

一.概述 QT实现USB通讯这里主要介绍两种方法,一种是通过libusb库来实现usb通讯,一种是通过hidapi库实现通信。 1.介绍libusb库 libusb 是一个 C 库,提供对 USB 设备的通用访问。 可移植的:使用单个跨平台API,它可以…

一、防御保护---信息安全概述

一、网络安全防御---信息安全概述 1.信息安全现状及挑战1.1 网络空间安全市场在中国,潜力无穷1.2 数字化时代威胁升级1.3 传统安全防护逐步失效1.4 安全风险能见度不足1.5 缺乏自动化防御手段1.6 网络安全监管标准愈发严苛 2.信息安全概述2.1 简介2.2 常见的网络安全…

Java 设计者模式以及与Spring关系(四) 代理模式

目录 简介: 23设计者模式以及重点模式 代理模式(Proxy Pattern) 静态代理示例 spring中应用 动态代理 1.基于JDK的动态代理 target.getClass().getInterfaces()作用 内名内部类写法(更简洁,但不推荐) 2.基于CGLIB实现 spring中应用 …

uniapp使用自定义组件

tt.vue中使用video-player组件 用到的目录如下: pages.json {"path": "pages/Tabbar/tt/tt","style": {"navigationBarTitleText": "","enablePullDownRefresh": false,// 使用自定义组件"using…

C++ 类定义

C 类定义 定义一个类需要使用关键字 class,然后指定类的名称,并类的主体是包含在一对花括号中,主体包含类的成员变量和成员函数。 定义一个类,本质上是定义一个数据类型的蓝图,它定义了类的对象包括了什么&#xff0…

【论文阅读笔记】Swin-Unet: Unet-like Pure Transformer for Medical Image Segmentation

1.介绍 Swin-Unet: Unet-like Pure Transformer for Medical Image Segmentation Swin-Unet:用于医学图像分割的类Unet纯Transformer 2022年发表在 Computer Vision – ECCV 2022 Workshops Paper Code 2.摘要 在过去的几年里,卷积神经网络&#xff…

14.任务管理系统

功能描述 角色 管理员、项目经理、员工 管理员功能 录入基础信息、用户信息。 项目经理功能 登陆系统录入项目信息、需求信息、拆解任务、分配任务 员工功能 登陆系统,查看任务、记录任务工作日志、完成任务。 数据模型 项目表 t_jd_project 字段名 类型 …

x-cmd pkg | dasel - JSON、YAML、TOML、XML、CSV 数据的查询和修改工具

目录 简介首次用户快速实验指南基本功能性能特点竞品进一步探索 简介 dasel,是数据(data)和 选择器(selector)的简写,该工具使用选择器查询和修改数据结构。 支持 JSON,YAML,TOML&…

CentOS 7 安装配置MySQL

目录 一、安装MySQL​编辑​编辑 1、检查MySQL是否安装及版本信息​编辑 2、卸载 2.1 rpm格式安装的mysql卸载方式 2.2 二进制包格式安装的mysql卸载 3、安装 二、配置MySQL 1、修改MySQL临时密码 2、允许远程访问 2.1 修改MySQL允许任何人连接 2.2 防火墙的问题 2…

大哈的变换迷宫的题解

目录 原题描述: 【题目描述】 【输入格式】 【输出格式】 【样例输入】 【样例输出】 【数据范围】 题目大意: 主要思路: 代码code(附有注释) 时间限制: 1000ms 空间限制: 524288kB 原题描述: …

【webrtc】跟webrtc学时间戳、序号类型转换

间隔ms src\modules\congestion_controller\remb_throttler.ccnamespace {constexpr TimeDelta kRembSendInterval = TimeDelta::Millis(200); } // namespace百分比的处理 src\modules\congestion_controller\remb_throttler.ccvoid RembT

行业-职业-大全-JSON

数据来源: https://blog.csdn.net/wjwABCDEFG/article/details/115669504 已将JSON进行格式处理 [{"Industry": "人事/行政/后勤","Occupations": ["人事专员/助理","人事信息系统(HRIS)管理","人事总监…