news 2026/2/22 23:42:18

15. 实时数据- SSE VS WebSocket

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
15. 实时数据- SSE VS WebSocket

文章目录

  • 前言
  • 一、基本概念
    • 1. Server-Sent Events (SSE)
    • 2. WebSocket
  • 二、核心对比
  • 三、代码示例
    • SSE(客户端)
    • WebSocket(客户端)
    • 四、如何选择?
    • 五、常见误区
    • 六、总结

前言

SSE VS WebSocket

Server-Sent Events(SSE) 和 WebSocket 都是用于实现 服务器向客户端推送数据 的 Web 通信技术,但它们在协议、能力、适用场景等方面有显著区别。


一、基本概念

1. Server-Sent Events (SSE)

  • 基于HTTP/1.1 或 HTTP/2的单向通信协议。
  • 服务器 → 客户端单向实时推送
  • 使用标准的text/event-streamMIME 类型。
  • 客户端通过EventSourceAPI 接收数据。
  • 自动重连、支持事件 ID、简单易用。

✅ 适用于:新闻推送、股票行情、日志流、通知等只读实时更新场景。

2. WebSocket

  • 基于独立的 WebSocket 协议(ws:// 或 wss://)
  • 全双工、双向通信:客户端和服务器可随时互相发送消息。
  • 建立连接需通过 HTTP 协议“升级”(Upgrade: websocket)。
  • 使用WebSocketJavaScript API。
  • 无内置重连机制,需自行实现。

✅ 适用于:聊天应用、在线游戏、协同编辑、实时交易系统等需要双向交互的场景。


二、核心对比

特性Server-Sent Events (SSE)WebSocket
通信方向单向(服务器 → 客户端)双向(全双工)
协议基础HTTP/HTTPS独立的 WebSocket 协议(基于 TCP)
浏览器支持广泛(除 IE)广泛(IE10+)
数据格式文本(通常是 UTF-8)文本或二进制
自动重连✅ 内置(可配置)❌ 需手动实现
消息类型支持自定义事件类型(event:字段)所有消息统一处理
跨域支持受 CORS 控制(标准 HTTP 行为)握手阶段受 CORS 控制
代理/防火墙兼容性✅ 极好(走标准 HTTP 端口)⚠️ 某些企业防火墙可能阻断非 HTTP 流量
开销轻量(复用 HTTP 连接)初始握手稍重,但后续高效
安全性支持 HTTPS(即 SSE over TLS)支持 WSS(WebSocket Secure)

三、代码示例

SSE(客户端)

consteventSource=newEventSource('/events');eventSource.onmessage=function(event){console.log('收到消息:',event.data);};eventSource.addEventListener('price-update',function(event){console.log('价格更新:',event.data);});// 自动重连(默认每3秒,可通过服务器返回 retry: 指令调整)

服务器响应(Node.js 示例)

HTTP/1.1 200 OK Content-Type: text/event-stream Cache-Control: no-cache Connection: keep-alive data: {"time": "2025-12-16T11:30:00Z"} event: price-update data: {"symbol": "AAPL", "price": 192.34}

WebSocket(客户端)

constws=newWebSocket('wss://example.com/chat');ws.onopen=()=>{ws.send(JSON.stringify({type:'join',room:'lobby'}));};ws.onmessage=(event)=>{constmsg=JSON.parse(event.data);console.log('收到:',msg);};ws.onclose=()=>console.log('连接关闭');

服务器(伪代码)

# 接收客户端消息并广播给其他用户asyncdefhandle_websocket(websocket,path):asyncformessageinwebsocket:awaitbroadcast(message)

四、如何选择?

场景推荐技术
仅需服务器推送更新(如通知、监控)SSE(更简单、省资源)
需要客户端频繁发消息给服务器(如聊天、游戏)WebSocket
需要传输二进制数据(如音视频、文件)WebSocket
部署环境限制只能用 HTTP(S) 端口SSE(兼容性更好)
已使用 HTTP/2,希望复用连接SSE over HTTP/2(多路复用更高效)

💡 小技巧:即使使用 WebSocket,也可以用 SSE 作为降级方案(例如在不支持 WebSocket 的旧设备上)。


五、常见误区

  • ❌ “SSE 是过时的技术” → 错!SSE 在现代 Web 应用中依然非常实用,尤其在 Serverless / HTTP-first 架构中。
  • ❌ “WebSocket 总是比 SSE 快” → 不一定。对于只读流,SSE 开销更低,且天然支持 HTTP 缓存、压缩、认证等。
  • ❌ “SSE 不能传 JSON” → 可以!event.data是字符串,通常就是 JSON。

六、总结

技术优势局限
SSE简单、自动重连、HTTP 原生、低开销单向、仅文本、不支持 IE
WebSocket双向、支持二进制、低延迟复杂、需管理连接、防火墙可能拦截

🎯原则

  • 如果你只需要“服务器告诉客户端发生了什么” → 选SSE
  • 如果你需要“客户端和服务器随时对话” → 选WebSocket

本文的引用仅限自我学习如有侵权,请联系作者删除。
参考知识


版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/15 18:24:22

FaceFusion局域网访问设置方法

FaceFusion局域网访问设置方法 在使用 FaceFusion 这类基于 Web UI 的人脸替换与增强工具时,很多用户会遇到一个常见需求:希望在局域网内的其他设备(如平板、手机或其他电脑)上也能访问和操作 FaceFusion 界面。这在团队协作、远…

作者头像 李华
网站建设 2026/2/21 2:59:36

Stable Diffusion 3.5 发布:图像生成新突破

Stable Diffusion 3.5 FP8 发布:图像生成效率的新拐点 你有没有遇到过这种情况?明明写好了精炼的提示词,构图、光影、风格都描述得清清楚楚,结果模型要么“选择性失明”,要么生成一堆模糊拼贴——更别提在16GB显存的消…

作者头像 李华
网站建设 2026/2/16 12:53:18

未来的App不再需要菜单栏?

2013年,电影《她》(Her)描绘了一个令人着迷又略带不安的未来:人类与操作系统通过自然语言持续对话,AI不仅理解语义,还能感知情绪、记住过往、主动推理——它不再是工具,而是一个“认知伙伴”。 …

作者头像 李华
网站建设 2026/2/22 4:45:48

Flutter 勇闯2D像素游戏之路(三):人物与地图元素的交互

Flutter 勇闯2D像素游戏之路(一):一个 Hero 的诞生 Flutter 勇闯2D像素游戏之路(二):绘制加载游戏地图 Flutter 勇闯2D像素游戏之路(三):人物与地图元素的交互 前言 在…

作者头像 李华
网站建设 2026/2/21 7:11:48

用PyTorch实现轴承故障诊断:多尺度卷积+注意力机制实战

基于多尺度卷积神经网络的滚动轴承故障诊断 针对传统方法在难以自适应提取滚动轴承有效故障特征信息的问题,提出了一种多尺度卷积神经网络的滚动轴承故障诊断方法。 首先,构建了多尺度特征融合模块自适应提取故障样本不同感受野下的特征表示,…

作者头像 李华
网站建设 2026/2/20 8:27:52

基于matlab的凸轮轮廓的设计计算与绘图 计算此结构的最优化参数,根据其原理输出推程和回程的...

基于matlab的凸轮轮廓的设计计算与绘图 计算此结构的最优化参数,根据其原理输出推程和回程的最大压力角、最小曲率半径等相关结果。 程序已调通,可直接运行。打开MATLAB的脚本编辑器,迎面扑来的是熟悉的蓝色界面。咱们今天要折腾的这个凸轮设…

作者头像 李华