LOGO OA教程 ERP教程 模切知识交流 PMS教程 CRM教程 开发文档 其他文档  
 
网站管理员

Web 实时通信:从短轮询到 WebSocket

admin
2025年8月15日 14:2 本文热度 47

在互联网早期,网页像一本翻页杂志:用户点击,浏览器请求,服务器响应,页面刷新。当产品经理提出“实时聊天”“股价闪动”“库存秒变”这些需求时,HTTP 的“请求—响应”模型立刻显得力不从心。于是,开发者经历了一场从“笨拙轮询”到“优雅全双工”的技术进化。今天,就让我们再走一遍这条路。

一、短轮询

思路简单到极致:

客户端每隔 X 秒发一次 Ajax,问“有新消息吗?”服务器答“没有”——循环往复。

伪代码

痛点

  • 空包占比高:99% 的请求是无用往返。

  • 连接反复建立:TCP 三次握手 + 四次挥手成了“日常运动”。

  • 延迟不可控:最快也要等到下一个轮询周期。

短轮询就像给服务器打“骚扰电话”,简单,却低效。

二、长轮询

聪明的工程师想到:

把电话“挂起不挂线”。客户端发起 Ajax,服务器夯住这个连接,直到真的有消息才返回;客户端收到后立即再挂一个,如此循环。

优势

  • 零空包:每次响应都携带数据。

  • 减少连接数:TCP 复用率提高。

新问题

  • 超时风险:浏览器/代理可能粗暴切断长连接。

  • 资源悬挂:服务器需要为大量空闲连接维持线程或内存。

  • 实时性仍受“挂起窗口”限制。

长轮询把“骚扰电话”变成了“占线等待”,但线路资源依旧吃紧。

三、WebSocket

HTML5 带来了 WebSocket——基于 TCP 的全双工通道

握手阶段仍用 HTTP,升级协议后,双方可随时推送数据帧

1. 握手:HTTP 的极限操作

客户端:

服务器返回 101:

状态码 101 表示:协议升级完成。此后数据帧不再走 HTTP。

2. 通信:帧级协议,双向飞驰

  • **帧(frame)**是最小单位,携带 payload、opcode、掩码。

  • **流(stream)**由帧组成,任何一方都可主动发送。

  • 无队头阻塞:不同消息并行交错,靠帧头 id 区分归属。

3. 代码示例(Node + 前端)

前端

Node 后端(ws 库)

四、使用场景与权衡

阅读原文:点击这里


该文章在 2025/8/15 20:59:53 编辑过
关键字查询
相关文章
正在查询...
点晴ERP是一款针对中小制造业的专业生产管理软件系统,系统成熟度和易用性得到了国内大量中小企业的青睐。
点晴PMS码头管理系统主要针对港口码头集装箱与散货日常运作、调度、堆场、车队、财务费用、相关报表等业务管理,结合码头的业务特点,围绕调度、堆场作业而开发的。集技术的先进性、管理的有效性于一体,是物流码头及其他港口类企业的高效ERP管理信息系统。
点晴WMS仓储管理系统提供了货物产品管理,销售管理,采购管理,仓储管理,仓库管理,保质期管理,货位管理,库位管理,生产管理,WMS管理系统,标签打印,条形码,二维码管理,批号管理软件。
点晴免费OA是一款软件和通用服务都免费,不限功能、不限时间、不限用户的免费OA协同办公管理系统。
Copyright 2010-2025 ClickSun All Rights Reserved