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

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

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


http://www.gsyq.cn/news/111000.html

相关文章:

  • 2025武汉户外广告批发口碑榜:十大高性价比推荐,户外广告/电梯框架广告/商圈广告/社区广告/电梯电子屏广告/应援广告户外广告品牌口碑推荐 - 品牌推荐师
  • 2025年行业内评价高的清障车专业厂家推荐榜单,高空作业车/云梯高空作业车/二手拖车清障车/二手蓝牌平板拖车清障车实力厂家怎么选择 - 品牌推荐师
  • LobeChat能否控制智能家居?物联网中枢大脑
  • 基于ATP-EMTP的500kV空载线路电弧重燃非同期合闸与分闸操作过电压
  • 用Wan2.2-T2V-A14B实现720P高保真视频生成
  • ‌《独家揭秘:核电应急机组大修背后的百亿市场链条》
  • 用PyTorch实现轴承故障诊断:多尺度卷积+注意力机制实战
  • MATLAB基础应用精讲-【自动驾驶】SORT目标跟踪算法(附python代码实现)
  • 性能测试的五个核心指标解析
  • 互联网大厂Java面试实录:谢飞机的能源与环保求职之旅 - 从Spring Boot到智能电网优化
  • openFuyao多样化算力使能
  • 无刷直流电机PI控制:Matlab Simulink仿真实践与解析本篇详述了仿真搭建、波形...
  • Transformer模型完全指南:从零开始学习大模型架构【收藏必学】
  • AI纪元2025终章:开源革命、监管铁幕与人类主体性的觉醒
  • 自动紧急制动系统仿真实战手记
  • 腾讯云国际站代理商的TAPD有什么优势呢?
  • AI模型训练入门指南:手把手教你构建自己的智能模型
  • 中小企业的营销“暖心伙伴”——北京易美之尚,让增长不再难
  • HC32F460 DMA的链式传输(SPI从机+DMA发送/接收)
  • 新国标电动车爬坡困境:当限速25km/h遭遇安全危机,无责伤亡谁来买单?
  • 腾讯云国际站代理商的定制化技术支持服务的成功案例有哪些?
  • VonaJS是如何做到文件级别精确HMR(热更新)的?
  • 爱舞功小程序+SaaS管理系统项目平台介绍说明书
  • 认知导向即面向服务——规避未来AI发展路径上的拟人化陷阱
  • Docker与本地PaddleOCR环境配置指南
  • API测试完整流程解析与最佳实践
  • ANT 设备(骑行台 FE-C 场景)开发的重点与难点全解析
  • MASIL玛丝兰发膜:用科技解锁秀发修护新方案 - 海棠依旧大
  • MASIL玛丝兰洗发水:专利护航,精准适配细分洗护需求 - 海棠依旧大
  • LobeChat能否实现AI编剧?电影剧本创意生成与结构优化