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

WebSocket简单了解

WebSocket 是一种计算机网络通信协议,它在客户端和服务器之间建立一个持久的、双向的通信通道。与传统的 HTTP 请求-响应模型不同,WebSocket 允许数据在客户端和服务器之间实时双向传输,因此非常适合需要即时交互的应用,如实时聊天、在线游戏、股票行情等。

WebSocket 的工作原理

  1. 建立连接:
    WebSocket 通过 HTTP 协议进行握手,以便建立初始连接。具体流程如下:

    • 客户端向服务器发送一个 WebSocket 握手请求(HTTP 请求)。这个请求的标志是 Upgrade 头部字段,告诉服务器要升级为 WebSocket 协议。
    • 服务器接收到这个请求后,如果支持 WebSocket 协议,会返回一个带有 101 Switching Protocols 状态码的 HTTP 响应,表示切换到 WebSocket 协议。

    一旦这个握手成功,连接就被升级为 WebSocket 连接,后续的通信就不再使用 HTTP 协议,而是使用 WebSocket 协议。

  2. 双向通信:

    • 一旦建立连接,客户端和服务器可以相互发送消息,而不需要像 HTTP 那样每次都重新建立连接。双方可以随时发送数据包(称为“消息”)。
    • WebSocket 协议支持文本消息和二进制消息(如图像或文件)。数据可以是 UTF-8 编码的文本,也可以是 二进制数据(如 Blob 或 ArrayBuffer)。
  3. 关闭连接:

    • 一旦通信结束,任何一方都可以发起关闭连接的请求。关闭过程也是通过 WebSocket 协议的帧(frame)来实现的。关闭连接时,双方会交换一个特殊的“关闭帧”。

WebSocket 的优点

  1. 实时性:
    WebSocket 提供了一个全双工的通信通道,可以在客户端和服务器之间实现实时数据传输。比如,股票行情、实时聊天、多人在线游戏等都可以通过 WebSocket 实现。

  2. 减少延迟:
    与传统的轮询机制相比,WebSocket 消除了每次请求都建立新连接的开销,减少了延迟。

  3. 节省带宽:
    WebSocket 连接一旦建立,后续的数据传输是基于持久连接的,因此减少了频繁的请求和响应,节省了带宽。

  4. 双向通信:
    WebSocket 支持双向通信,可以让客户端和服务器随时互相发送消息。这对于许多应用非常重要,例如即时消息和推送通知。

WebSocket 与 HTTP 的区别

特性WebSocketHTTP
连接方式双向通信,持久连接,持久握手单向通信,每次请求-响应都需要建立新的连接
消息传输方式双向实时传输(可以推送数据)客户端请求后,服务器响应一次,不能主动发送数据
建立连接的开销只需一次握手即可,后续消息传输没有开销每次请求都要建立新连接
应用场景实时应用,如在线游戏、股票行情、实时聊天等页面请求、资源请求、API调用等

WebSocket 示例

以下是一个简单的 WebSocket 客户端和服务器的实现示例:

1. WebSocket 客户端 (JavaScript)
// 创建 WebSocket 连接
const socket = new WebSocket('ws://localhost:8080');// 当连接成功时触发
socket.onopen = function() {console.log('WebSocket连接已打开');// 发送消息socket.send('Hello, Server!');
};// 当接收到消息时触发
socket.onmessage = function(event) {console.log('收到消息:', event.data);
};// 当连接关闭时触发
socket.onclose = function() {console.log('WebSocket连接已关闭');
};// 发生错误时触发
socket.onerror = function(error) {console.log('WebSocket发生错误:', error);
};
2. WebSocket 服务器 (Node.js 示例)
const WebSocket = require('ws');// 创建 WebSocket 服务器
const wss = new WebSocket.Server({ port: 8080 });wss.on('connection', function(ws) {console.log('客户端已连接');// 监听客户端消息ws.on('message', function(message) {console.log('收到客户端消息:', message);// 回复客户端ws.send('Hello, Client!');});// 客户端连接关闭时触发ws.on('close', function() {console.log('客户端连接关闭');});
});

常见的 WebSocket 用途

  1. 即时聊天应用:
    WebSocket 使得消息可以在服务器和多个客户端之间实时推送,适合构建即时聊天应用。

  2. 股票/金融行情:
    需要实时更新数据的应用,如股票、货币、商品行情,WebSocket 可以提供低延迟的实时数据推送。

  3. 在线游戏:
    多人在线游戏需要客户端和服务器之间实时交换数据,WebSocket 是实现这一需求的理想选择。

  4. 协作应用:
    在多人同时编辑文档、白板应用等场景中,WebSocket 可以实时同步每个用户的操作。

总结

WebSocket 是一种高效、低延迟的实时通信协议,适用于需要快速双向数据传输的应用。它通过减少连接开销、支持实时数据传输,使得客户端和服务器之间的交互更加高效。

http://www.dtcms.com/a/351507.html

相关文章:

  • 线性代数之深入理解旋转矩阵
  • lesson46-2:Linux 高级指令全解析:从文件操作到系统管理
  • mybatisplus 配置二级缓存
  • 【系统编程】线程简介
  • 【人工智能】2025年AI代理开源革命:社区驱动的智能体生态重塑未来
  • Linux--seLinux的概述
  • FRET、PLA、Co-IP和GST pull-down有何区别? 应该如何选择?
  • 原型模式系统开发中的原型分类全景:水平、垂直、抛弃式与演化式
  • nvm切换node版本之后报错,无法将“node”项识别为 cmdlet、函数、脚本文件或可运行程序的名称
  • 嵌入式C语言进阶:结构体封装函数的艺术与实践
  • IUV5G专网排障(上)
  • 支持向量机(SVM)学习笔记
  • SOME/IP服务发现PRS_SOMEIPSD_00277的解析
  • 服务器数据恢复—热备盘上线失败如何恢复数据?
  • 【Android】webview强制Crash后再自恢复设计
  • 服务器初始化
  • 影响服务器托管费用的因素​
  • ROS2 Helloworld 入门——包含完整pdf手册
  • Linux驱动开发笔记(九)——内核定时器
  • CSS 优先级:公司组织架构模型
  • css3背景线性渐变:linear-gradient
  • 基于Python+MySQL实现物联网引论课程一个火警报警及应急处理系统
  • 面向 6G 网络的 LLM 赋能物联网:架构、挑战与解决方案
  • 相机激光安全等级和人眼安全
  • 第九届MathorCup高校数学建模挑战赛-D题:钢水“脱氧合金化”配料方案的优化
  • 五自由度磁悬浮轴承同频振动抑制:从机理拆解到传递函数验证的核心方案
  • 【图像算法 - 24】基于深度学习与 OpenCV 实现人员跌倒识别系统(目标检测方案 - 跌倒即目标)
  • Baumer高防护相机如何通过YoloV8深度学习模型实现形状检测器的使用(YOLOv8 Shape Detector)
  • 无人机航拍数据集|第32期 无人机采矿区作业目标检测YOLO数据集202张yolov11/yolov8/yolov5可训练
  • GaussDB 数据库架构师修炼(十八) SQL引擎-计划管理-SPM