了解 WebSocket 和 TCP :有何不同

news2024/11/27 8:36:13

WebSocket — 双向通讯的艺术

WebSocket Illustration

简要概述

WebSocket 代表着WebSocket通讯协议,提供了一条用于客户端和服务器间实现实时、双向、全双工通信的渠道。在WebSocket引入之前,网页应用的数据更新依赖于频繁的轮询,这种做法不仅效率低下,还带来了巨大的网络资源浪费。相比之下,WebSocket的出现为网页应用提供了一种更快、更简便和资源利用率更高的数据交换方式。

WebSocket主要特征包括:

  • 互动性:支持从客户端到服务器端,也支持从服务器端到客户端的不间断数据流动。
  • 即时更新:可以实现页面的即时更新而无需刷新。
  • 低延迟:通过最小化网络流量和减少数据传输来提高性能,使得延迟降到最低。
  • 高兼容性:大多数现代浏览器都支持WebSocket通信。
  • 加密传输:通过TLS/SSL机制保障数据传输安全。
  • 跨平台灵活性:WebSocket可在多种开发语言和不同平台上实施,并支持移动端应用。

在前端的实施

通过WebSocket API,开发者在网页应用中得以使用WebSocket。这个API包含如下组件:

  • WebSocket对象:负责创建WebSocket连接的 JavaScript 对象。
  • WebSocket事件:包括:
    • open:连接成功后触发。
    • close:连接关闭时触发。
    • message:接收消息时触发。
    • error:连接发生错误时触发。
  • WebSocket属性:对象的属性包括readyState、bufferedAmount等。

除了API接口,还有如协议升级和数据帧格式的多个WebSocket规范,确保了不同的实现能够互通。

TCP 协议

TCP Illustration

基本概述

传输控制协议(TCP)是一种可靠的、基于连接的通讯协议,广泛应用于互联网传输中。它确保网络层的数据安全有效传递,并负责传输层的数据传递管理。

TCP的核心特性包括:

  • 可靠传输:确保数据包能完整且准确的到达目的地。
  • 连接型服务:在数据传输前需建立连接并在结束后断开连接。
  • 流量控制:调整数据传输速度,防止网络拥堵。
  • 拥堵控制:降低数据传输速度以缓解网络拥堵。
  • 数据包头部负担:需要额外头部信息来维护连接状态和控制流量,导致每个包的有效载荷减少。

工作原理

TCP的工作机制涉及:

  • 将数据分割成多个包并附加必要的头部信息,如源地址、目标地址和序列号等。
  • 接收方收到数据包后,校验完整性,确认无误后发送 ACK 回复。
  • 发送方接收 ACK 信号,以确定数据成功传递。

WebSocket 与 TCP 的异同

加深理解 WebSocket 和 TCP 关系

WebSocket 作为运行于TCP之上的一种高效通信协议,它提供了长期开启的客户端和服务器之间双向通信通道,与TCP三次握手过程类似。WebSocket的握手通过HTTP完成。建立后,通道保持开放以进行数据交换,确保了TCP协议的可靠性和流量控制。

核心差异

WebSocket和TCP之间的主要差异可总结为:

  • 建立连接: WebSocket除了经典的TCP三次握手以外,还需要 HTTP 协议头中的Upgrade字段以升级至WebSocket连接。
  • 数据传输单位: WebSocket更倾向于以消息为单位传输数据,而TCP则是字节流。
  • 数据处理: WebSocket相对于TCP,添加了数据压缩和消息分片的额外处理。
  • 实时性: 保持连接状态下的WebSocket通讯协议具备更高的实时交互能力。

调试 TCP 及 WebSocket 接口实例

Apifox 软件为例,下文将展现如何发送TCP和WebSocket请求。

调试 TCP 示例

发送TCP请求需要:

  • 建立请求,并填入URL、请求方法、名称。
  • 在运行页面发送请求。

Apifox TCP Request

  • 若需Mock数据,切换至本地Mock环境。

Apifox TCP Mock

新建及测试 WebSocket 连接

在Apifox中创建一个WebSocket请求步骤包括:

  • 点击创建按钮。
  • 输入WebSocket服务的地址。
  • 填写消息内容和参数。

WebSocket Create Request

发送消息和参数给服务器,以及如何保存WebSocket请求的步骤:

  • 输入Message中的内容将被传输至服务器。
  • 使用Params传输参数或查询字符串。
  • 保存请求便于后续使用。

WebSocket Save Request

建立并发送WebSocket请求:

  • 与服务端建立WebSocket连接。
  • 发送消息并接收服务器回应。

WebSocket Open Connection

  • 服务端接收连接后的反馈信息。

WebSocket Feedback

  • 使用Apifox发送消息,服务端像客户端一样可发送返回信息,例如时间戳。

WebSocket Communication

总结

通过深入理解WebSocket和TCP协议,我们得以为Web应用开发提供实时、高效的通信解决方案。WebSocket在TCP的稳固基础上加入了全双工通信特性,为用户交互和实时数据传输开辟了新天地。利用Apifox等工具的便利性,开发者能够轻松地调试和优化这些协议的应用,确保现代Web应用的通信无缝且高效。

知识扩展

  • WebSocket 与 Socket、TCP、HTTP 的关系及区别
  • WebSocket 和 HTTP 的区别深解

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

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

相关文章

上位机是什么?与下位机是什么关系

在工业自动化领域中,上位机是一项关键而引人注目的技术。许多人对上位机的概念感到好奇,想要深入了解其在工业智能中的作用。那么,上位机究竟是什么呢? 首先,上位机是一种用于工业控制系统的软件应用,通常…

elementUI中表单校验的清空校验以及手动校验

this.$refs.表单.clearValidate(),这个可以传入字符串或者字符串数组,字符串对应的是我们自定义的rule里面的属性名,rule的属性名对应的是el-form-item的prop。这个api目前遇到的场景是el-radio切换时v-if展示不同的表单内容,但是当有校验提示…

把成绩私发给家长

与家长保持及时、有效的沟通对于学生的成长至关重要。但有时候,我会选择将学生的成绩私发给家长,而不是在公共场合公布。这样做有以下几个原因。 保护学生的隐私。每个学生都拥有自己的个人信息,这包括学习成绩。在公共场合公布成绩&#xf…

前后端项目

文章目录 1.需求2.项目搭建2.1项目结构图2.2构建聚合工程2.2.1 zx-parent父工程2.2.2 zx-framework父工程2.2.2.1 zx-common工程2.2.2.2 zx-mybatisplus工程2.2.3 如上,同理创建其他父子工程2.3准备sql3.用户登录3.1 修改pom-依赖其他Module3.2 封装User1.需求 在线学习平台 …

vue3-深入组件-插槽

插槽 Slots 组件用来接收模板内容 插槽内容与出口 <slot> 元素是一个插槽出口 (slot outlet),&#xff0c;标示了父元素提供的插槽内容 (slot content) 将在哪里被渲染。 插槽内容可以是任意合法的模板内容&#xff0c;不局限于文本。例如我们可以传入多个元素&#xff0…

版本管理工具git: 谨慎使用git中的撤回操作

文章目录 一、背景二、解决方案1、步骤一2、步骤二 三、参考 一、背景 昨天代码分支提交错了&#xff0c;idea中使用了如下操作&#xff0c;结果代码不见了 二、解决方案 1、步骤一 使用git reflog命令&#xff0c;查看提交记录&#xff0c;找到之前commit操作的哈希值 …

二叉树顺序结构堆实现

目录 Test.c测试代码 test1 test2 test3 &#x1f387;Test.c总代码 Heap.h头文件&函数声明 头文件 函数声明 &#x1f387;Heap.h总代码 Heap.c函数实现 ☁HeapInit初始化 ☁HeapDestroy销毁 ☁HeapPush插入数据 【1】插入数据 【2】向上调整Adjustup❗ …

Java JVM类加载阶段 双亲委派模式

类加载阶段 加载 将类的字节码载入方法区中&#xff0c;内部采用 C 的 instanceKlass 描述 java 类&#xff0c;它的重要 field 有&#xff1a; _java_mirror 即 java 的类镜像&#xff0c;例如对 String 来说&#xff0c;就是 String.class&#xff0c;作用是把 klass 暴露…

中国2023年土地利用现状遥感监测数据

中国2023年土地利用现状遥感监测数据是以2023年美国Landsat 8遥感影像为主要数据源&#xff0c;在2020年通过2020年土地利用数据基础上&#xff0c;通过2020年和2023年两期遥感影像对比分析&#xff0c;人工目视解译生成。 改革开放以来&#xff0c;中国经济的快速发展对土地利…

Docker进阶篇-reids集群

一、集群存储算法 分布式存储的常见算法&#xff1a; 哈希取余分区 一致性哈希算法分区 哈希槽分区 1、哈希取余分区 描述&#xff1a;每次读写操作都是根据公式&#xff1a;Hash(key) % N&#xff08;其中&#xff0c;key是要存入Redis的键名&#xff0c;N是 Redis集群的…

编程实例分享,配件进销存进出库管理系统软件

编程实例分享&#xff0c;配件进销存进出库管理系统软件 一、前言 以下教程以 佳易王配件进出库管理系统软件V16.0为例说明 如上图&#xff0c;左侧为导航栏&#xff0c;分为 系统设置&#xff0c;用户信息设置&#xff0c;出入库开单&#xff0c;统计报表&#xff0c;财务管…

BPF 管理器 bpfman 简介

1. 背景 Fedora 40 提案建议将 bpfman 作为默认的程序管理器 &#xff0c;开源项目 bpfman 可以实现对 eBPF 运行状态的深入了解&#xff0c;从而实现更轻松地管理 eBPF 程序&#xff08;包括加载、卸载、运行状态查看等&#xff09;。该提案还需要 Fedora 工程和指导委员会 (…

1.31学习总结

1.31 1.线段树 2.Bad Hair Day S&#xff08;单调栈&#xff09; 3.01迷宫(BFS连通块问题剪枝)&#xff08;连通性问题的并查集解法&#xff09; 4.健康的荷斯坦奶牛 Healthy Holsteins&#xff08;DFS&#xff09; 线段树与树状数组 线段树和树状数组的功能相似&#xff0c;但…

社交买量:归因统计的核心要素与工具

在当今的社交App推广领域&#xff0c;广告买量已成为企业获取用户的重要手段。然而&#xff0c;如何准确衡量这些买量活动的成效&#xff0c;即用户从广告访问到安装后行为的完整转化路径&#xff0c;一直是运营人员关注的焦点。归因统计是一种评估营销效果的关键技术方案&…

制造业实施QMS质量管理系统的作用是什么?

QMS质量管理系统是一个关键的组织管理工具&#xff0c;用于确保产品和服务的质量符合预期标准&#xff1b;通过有效地实施万界星空科技QMS&#xff0c;组织可以确保产品和服务的质量符合预期标准&#xff0c;提升客户满意度&#xff0c;增强市场竞争力。 一、QMS系统的特点&…

找出最可疑的嫌疑人 - 华为机试真题题解

考试平台&#xff1a; 时习知 分值&#xff1a; 100分&#xff08;第一题&#xff09; 考试时间&#xff1a; 2024-01-31 &#xff08;两小时&#xff09; 题目描述 民警侦办某商场店面盗窃案时&#xff0c;通过人脸识别针对嫌疑人进行编号1-100000。 现在民警在监控记录中发…

Prometheus---图形化界面grafana(二进制)

前言 Prometheus是一个开源的监控以及报警系统。整合zabbix的功能&#xff0c;系统&#xff0c;网络&#xff0c;设备。 proetheus可以兼容网络&#xff0c;设备。容器的监控。告警系统。因为他和k8s是一个项目基金开发的产品&#xff0c;天生匹配k8s的原生系统。容器化和云原…

运动编辑学习笔记

目录 跳舞重建&#xff1a; 深度运动重定向 Motion Preprocessing Tool anim_utils MotionBuilder 跳舞重建&#xff1a; https://github.com/Shimingyi/MotioNet 深度运动重定向 https://github.com/DeepMotionEditing/deep-motion-editin 游锋生/deep-motion-editin…

Three.js学习1:threejs简介及文档本地部署

开一个天坑&#xff0c;Three.js 我觉得未来3D页面一定是一个趋势。 -----------------------------华丽的分割线------------------------- github&#xff1a;https://github.com/mrdoob/three.js/ 官网&#xff1a;Three.js – JavaScript 3D Library Threejs官网中文文…

自学Java的第十八天

一&#xff0c;每日收获 1.数组拷贝 2.数组反转 3.数组添加/扩容 二&#xff0c;新名词与小技巧 三&#xff0c;今天学习中所遇到的困难 一&#xff0c;每日收获 1.数组拷贝 编写代码 实现数组拷贝 将 int[] arr1 {10,20,30}; 拷贝到 arr2 数组 , 要求数据空间是独…