WebSocket介绍

WebSocket 是一种网络通信协议,它在单个 TCP 连接上提供全双工(full-duplex)通信信道。与传统的 HTTP 请求 - 响应模式不同,WebSocket 允许服务器和客户端在连接建立后随时互相发送数据,非常适合需要实时交互的应用场景(如在线聊天、实时游戏、股票行情推送、协同编辑等)。

以下是 WebSocket 的核心特点和工作机制:

1. 核心特点

  • 持久连接:一旦握手成功,连接会一直保持打开状态,直到某一方主动关闭。
  • 双向通信:服务器可以主动向客户端推送数据,无需客户端先发起请求。
  • 低延迟:避免了 HTTP 轮询(Polling)或长轮询(Long Polling)带来的额外头部开销和延迟。
  • 轻量级帧:数据传输使用轻量级的二进制或文本帧,头部开销极小(通常只有 2-14 字节)。

2. 工作原理

WebSocket 的通信过程主要分为两个阶段:

A. 握手阶段 (Handshake)

客户端通过 HTTP 协议发起一个特殊的升级请求,服务器如果支持 WebSocket,会返回一个状态码为 101 Switching Protocols 的响应,从而将协议从 HTTP 升级为 WebSocket。

客户端请求示例:

http

编辑

复制代码
GET /chat HTTP/1.1
Host: example.com
Upgrade: websocket
Connection: Upgrade
Sec-WebSocket-Key: dGhlIHNhbXBsZSBub25jZQ==
Sec-WebSocket-Version: 13

服务器响应示例:

http

编辑

复制代码
HTTP/1.1 101 Switching Protocols
Upgrade: websocket
Connection: Upgrade
Sec-WebSocket-Accept: s3pPLMBiTxaQ9kYGzzhZRbK+xOo=
B. 数据传输阶段

握手完成后,TCP 连接保持不变,双方可以通过这个连接随时发送数据帧(Frame)。数据可以是文本(Text)或二进制(Binary)。

3. 前端使用示例 (JavaScript)

在现代浏览器中,可以使用原生的 WebSocket API:

javascript

编辑

复制代码
// 1. 创建连接
const socket = new WebSocket('ws://example.com/socket');

// 2. 监听连接打开事件
socket.addEventListener('open', function (event) {
    console.log('连接已建立');
    // 发送数据
    socket.send('Hello Server!');
});

// 3. 监听接收消息事件
socket.addEventListener('message', function (event) {
    console.log('收到消息:', event.data);
});

// 4. 监听错误事件
socket.addEventListener('error', function (event) {
    console.error('发生错误:', event);
});

// 5. 监听连接关闭事件
socket.addEventListener('close', function (event) {
    console.log('连接已关闭');
});

4. 常见应用场景

  • 即时通讯 (IM):微信、Slack 等聊天软件的网页版。
  • 实时数据监控:股票交易大屏、服务器性能监控仪表盘。
  • 在线协作:Google Docs、Figma 等多人同时编辑工具。
  • multiplayer 在线游戏:需要极低延迟的状态同步。
  • 直播弹幕:高并发下的实时消息推送。

5. 与 HTTP/2 和 SSE 的区别

  • vs HTTP/2 Server Push: HTTP/2 主要是服务器推送资源,且仍是请求 - 响应模型的优化;WebSocket 是完全独立的双向协议。
  • vs SSE (Server-Sent Events) : SSE 仅支持单向 通信(服务器 -> 客户端),基于 HTTP 长连接,实现简单,适合新闻推送等场景;WebSocket 支持双向,功能更强大但实现稍复杂。
相关推荐
飞Link6 分钟前
【TCP\UDP与可靠传输】UDP 的“简单粗暴”和它真正适用的场景
网络·网络协议·tcp/ip·udp
天下无敌笨笨熊1 小时前
SNMP协议开发心得
网络协议·c#
AIFQuant1 小时前
量化私募回测系统:高质量股票/外汇历史数据 API 选型与接入
python·websocket·金融·ai量化
myenjoy_13 小时前
串口采集与 Modbus RTU——字节流里的时间敏感博弈
网络·python·网络协议·tcp/ip
代码中介商4 小时前
HTTP 完全指南(三):Cookie、Session 与 Token 深度详解
网络·网络协议·http
下北沢美食家6 小时前
WebSocket入门
网络·websocket·网络协议
zh路西法6 小时前
【rosbridge-websocket】跨网络的ROS1与ROS2通讯法(上)
linux·网络·c++·python·websocket·网络协议
.小小陈.7 小时前
应用层协议 HTTP 全解析:从基础到实战
网络·网络协议·http
酉鬼女又兒7 小时前
零基础入门计算机网络:点对点协议PPP、媒体接入控制基本概念、静态划分信道技术、CSMA/CD与CSMA/CA协议全面详解
服务器·网络·网络协议·计算机网络·职场和发展·求职招聘·媒体
酉鬼女又兒7 小时前
零基础快速入门IP编址计算练习题详解:从基础到实战
网络·网络协议·tcp/ip·计算机网络·考研·职场和发展·分类