news 2026/4/3 3:49:13

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/4/1 2:34:48

基于栈结构的贪心策略在有效括号问题中的应用与实现

摘要有效括号问题是算法领域的经典基础问题,其核心要求是判断给定括号字符串是否满足类型匹配与顺序匹配的双重约束。本文提出一种基于栈结构的贪心算法解决方案,通过局部最优选择(即遇到右括号时立即匹配最近的左括号)&#xff0…

作者头像 李华
网站建设 2026/3/30 22:47:18

小程序项目之驾校报名小程序源代码(java+vue+小程序+mysql)

大家好我是风歌,曾担任某大厂java架构师,如今专注java毕设领域。今天要和大家聊的是一款java小程序项目——驾校报名小程序。项目源码以及远程配置部署相关请联系风歌,文末附上联系信息 。项目简介:(1)管理…

作者头像 李华
网站建设 2026/4/1 18:04:17

33、FreeBSD 系统下的生产力与多媒体应用指南

FreeBSD 系统下的生产力与多媒体应用指南 1. 生产力应用介绍 1.1 KIllustrator KIllustrator 是一款用于创建插图的基础绘图程序。对于熟悉绘图软件的用户来说,适应 KIllustrator 应该比较容易。 1.2 StarOffice StarOffice 由 Sun Microsystems 提供,是一款功能齐全的桌…

作者头像 李华
网站建设 2026/4/1 13:04:37

38、邮件服务与文件共享全解析

邮件服务与文件共享全解析 1. 邮件中继问题及解决办法 在运行 SMTP 服务器时,邮件中继是一个常见的问题。有一个功能在默认的 freebsd.mc 中,但被注释掉了。若要启用它,需移除 dnl 注释并重新构建配置文件。 作为最后的手段,可以通过启用 promiscuous_relay 功能完…

作者头像 李华
网站建设 2026/3/28 11:10:16

YOLO系列进化史:从v1到v11的精度与速度突破

YOLO系列进化史:从v1到v11的精度与速度突破 在智能制造和智能视觉迅速发展的今天,一条SMT产线每秒要处理20块PCB板——这意味着留给缺陷检测的时间窗口不足50毫秒。传统图像处理算法面对复杂多变的焊点异常束手无策,而两阶段目标检测器又因延…

作者头像 李华