news 2026/3/20 21:34:37

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/3/13 0:51:28

25、配置 FreeBSD 拨号上网连接

配置 FreeBSD 拨号上网连接 在当今数字化时代,网络连接是我们生活和工作中不可或缺的一部分。对于使用 FreeBSD 系统的用户来说,配置拨号上网连接可能是一项具有挑战性但又十分必要的任务。本文将详细介绍如何在 FreeBSD 系统中配置拨号上网连接,包括所需的步骤、文件配置以…

作者头像 李华
网站建设 2026/3/14 2:31:44

29、X Window系统配置与启动指南

X Window系统配置与启动指南 1. 鼠标和键盘配置 1.1 鼠标类型与协议选择 如今,PS/2鼠标或USB鼠标较为常见,串口鼠标正逐渐被淘汰。使用 xf86config 程序配置X Window系统时,首先要以root用户登录,在命令提示符下输入 xf86config 启动程序。启动后,会要求选择鼠标协…

作者头像 李华
网站建设 2026/3/18 17:49:14

32、FreeBSD窗口管理器与桌面环境及办公软件全解析

FreeBSD窗口管理器与桌面环境及办公软件全解析 1. 窗口管理器与桌面环境的区别 在FreeBSD系统中,KDE是较为流行的桌面环境,但并非唯一选择,还有众多从简单到复杂的替代方案。窗口管理器和桌面环境存在明显差异: - 功能特性 :像KDE这样的桌面环境通常比单纯的窗口管理…

作者头像 李华
网站建设 2026/3/19 1:42:05

34、FreeBSD 多媒体与 Web 服务器使用指南

FreeBSD 多媒体与 Web 服务器使用指南 1. FreeBSD 多媒体功能 1.1 CD 播放器 KDE 自带了一个 CD 播放器,该播放器支持 CDDB 系统,这意味着它可以自动从互联网下载专辑和曲目信息。 1.2 混音器 FreeBSD 提供了一个可以通过命令行访问的混音器。 - 显示当前混音器设置 …

作者头像 李华
网站建设 2026/3/14 7:05:07

鸿蒙三方库—harmony-utils使用

简介 harmony-utils 一款功能丰富且极易上手的HarmonyOS工具库,借助众多实用工具类,致力于助力开发者迅速构建鸿蒙应用。其封装的工具涵盖了APP、设备、屏幕、授权、通知、线程间通信、弹框、吐司、生物认证、用户首选项、拍照、相册、扫码、文件、日志…

作者头像 李华