Server-Sent Events (SSE) 和 WebSocket 都是用于实现服务器与客户端实时通信的技术,但它们在设计目标、协议特性和适用场景上有显著区别。以下是两者的详细对比:


一、核心区别总结

对比维度 SSE (Server-Sent Events) WebSocket
通信方向 单向(服务器 → 客户端) 全双工(服务器 客户端)
协议基础 基于HTTP 独立协议(ws://wss://
数据格式 纯文本(事件流格式) 二进制或文本
自动重连 内置支持 需手动实现
浏览器兼容性 除IE外主流浏览器支持 所有现代浏览器支持
适用场景 服务器向客户端推送实时数据(如股票行情、新闻) 双向交互场景(如聊天、游戏、协同编辑)

二、技术细节对比

1. 连接建立

  • SSE

    // 客户端代码
    const eventSource = new EventSource("/sse-endpoint");
    eventSource.onmessage = (e) => console.log(e.data);
    • 使用标准HTTP请求,头部包含:
      Accept: text/event-stream
      Cache-Control: no-cache
      Connection: keep-alive
  • WebSocket

    // 客户端代码
    const socket = new WebSocket("ws://example.com/ws");
    socket.onmessage = (e) => console.log(e.data);
    • 通过HTTP Upgrade切换协议:
      GET /ws HTTP/1.1
      Upgrade: websocket
      Connection: Upgrade

2. 数据传输

  • SSE

    • 服务器响应格式:
      event: priceUpdate
      data: {"symbol":"AAPL","price":182.73}
      \n\n
    • 支持事件类型(event字段)和重试时间(retry字段)
  • WebSocket

    • 二进制或文本帧自由传输:
      // 发送文本
      socket.send("Hello Server!");
      // 发送二进制数据(如文件)
      socket.send(arrayBuffer);

3. 连接维护

特性 SSE WebSocket
心跳检测 依赖HTTP长连接 需手动实现Ping/Pong帧
断线重连 自动(客户端默认3秒重试) 需手动重连
连接状态管理 简单(HTTP状态码控制) 复杂(需处理多种帧类型)

三、选择建议

使用SSE的场景

  1. 服务器单向推送

    • 实时监控(服务器指标、日志流)
    • 新闻/股票行情推送
    • 长轮询替代方案
  2. 需要简单实现

    • 无需额外协议,复用HTTP基础设施
    • 自动重连和事件ID支持
  3. 文本数据为主

    • 结构化数据(JSON)传输

使用WebSocket的场景

  1. 双向交互需求

    • 在线聊天室
    • 多人在线游戏
    • 实时协作编辑
  2. 低延迟通信

    • 高频双向数据交换(如视频会议信令)
  3. 二进制数据传输

    • 文件传输、音视频流

四、代码示例对比

SSE实现(Spring Boot)

@GetMapping("/sse")
public SseEmitter streamData() {
SseEmitter emitter = new SseEmitter();
executor.execute(() -> {
try {
for (int i = 0; i < 10; i++) {
emitter.send(
SseEmitter.event()
.name("update")
.data("Event #" + i)
);
Thread.sleep(1000);
}
emitter.complete();
} catch (Exception e) {
emitter.completeWithError(e);
}
});
return emitter;
}

WebSocket实现(Spring Boot)

@Configuration
@EnableWebSocket
public class WebSocketConfig implements WebSocketConfigurer { @Override
public void registerWebSocketHandlers(WebSocketHandlerRegistry registry) {
registry.addHandler(myHandler(), "/ws")
.setAllowedOrigins("*");
} @Bean
public WebSocketHandler myHandler() {
return new TextWebSocketHandler() {
@Override
protected void handleTextMessage(WebSocketSession session, TextMessage message) {
// 处理客户端消息
session.sendMessage(new TextMessage("ECHO: " + message.getPayload()));
}
};
}
}

五、性能与资源消耗

指标 SSE WebSocket
连接开销 较高(HTTP头重复传输) 低(连接后无额外开销)
服务器内存占用 每个连接独立线程/连接 更高效的连接管理
适合连接数 适合中低并发(数千连接) 适合高并发(数万连接)

六、兼容性解决方案

当需要兼容老旧浏览器时:

  • SSE降级方案:使用长轮询(Long Polling)
  • WebSocket降级方案:使用SockJS库
    const sock = new SockJS('/ws-endpoint');
    sock.onmessage = (e) => console.log(e.data);

总结

  • SSE简单、单向实时通信的理想选择,尤其适合已有HTTP架构的项目。
  • WebSocket在需要双向、低延迟交互时不可或缺,但实现复杂度更高。

根据你的应用场景选择:

  • 只需接收服务器更新? → 用SSE
  • 需要双向对话? → 用WebSocket

即时通信SSE和WebSocket对比的更多相关文章

  1. .NET 即时通信,WebSocket服务端实例

    即时通信常用手段 1.第三方平台 谷歌.腾讯 环信等多如牛毛,其中谷歌即时通信是免费的,但免费就是免费的并不好用.其他的一些第三方一般收费的,使用要则限流(1s/限制x条消息)要么则限制用户数. 但稳 ...

  2. WebSocket实现web即时通信(后端nodejs实现)

    WebSocket实现web即时通信 一.首先看一下,HTTP.ajax轮询.long poll和WebSocket的区别: 1.HTTP 协议(短连接):一个 Request 一个 Response ...

  3. .NET实现WebSocket服务端即时通信实例

    即时通信常用手段 1.第三方平台 谷歌.腾讯 环信等多如牛毛,其中谷歌即时通信是免费的,但免费就是免费的并不好用.其他的一些第三方一般收费的,使用要则限流(1s/限制x条消息)要么则限制用户数. 但稳 ...

  4. .NET 即时通信,WebSocket

    .NET 即时通信,WebSocket 即时通信常用手段 1.第三方平台 谷歌.腾讯 环信等多如牛毛,其中谷歌即时通信是免费的,但免费就是免费的并不好用.其他的一些第三方一般收费的,使用要则限流(1s ...

  5. WebSocket实现Web端即时通信

    前言 WebSocket 是HTML5开始提供的一种在浏览器和服务器间进行全双工通信的协议.目前很多没有使用WebSocket进行客户端服务端实时通信的web应用,大多使用设置规则时间的轮询,或者使用 ...

  6. 即时通信WebSocket 和Socket.IO

    WebSocket HTML5定义了WebSocket协议,能更好的节省服务器资源和带宽,并且能够更实时地进行通讯. 在2008年诞生,2011年成为国际标准. 现在基本所有浏览器都已经支持了. We ...

  7. [Full-stack] 异步即时通信 - Async

    故事背景 socket.io, node.js, koa为首的一些通信框架和后端技术点. 之后有必要过一遍<NodeJS 设计模式>. 基础概念 一.短轮询.长轮询(comet).长连接( ...

  8. 即时通信之 SignalR

    即时通信在日常的web开发场景中经常使用,本篇主要回顾一下SignalR的实现原理和通过例子说明如何在.NET Core 中使用. SingnalR 应用 需要从服务器进行高频更新的应用程序.例如游戏 ...

  9. (转)基于即时通信和LBS技术的位置感知服务(一):提出问题及解决方案

    一.前言.提出问题 公司最近举行2011年度创新设计大赛,快年底了正打算写写2010年以来Android开发的心得与经验,正好同事出了个点子:假如A和B两个人分别在不同的地点,能不能实现这样的功能,让 ...

  10. Websql,应用程序缓存,WebWorkers,SSE,WebSocket

    ①什么是 Web Worker? 当在 HTML 页面中执行脚本时,页面的状态是不可响应的,直到脚本已完成. web worker 是运行在后台的 JavaScript,独立于其他脚本,不会影响页面的 ...

随机推荐

  1. Ubuntu13 安装vim

    问题 由于系统没有vim,只有vi,而vi 编辑文件时比较麻烦,不易操作,还没有关键词高亮显示等,故想安装vim 输入命令: sudo apt install vim 报错,找不到 apt 命令,即没 ...

  2. EndNote20在正文中修改引文格式的方法(只显示第一作者,其他部分显示et.al.)

    目前网上查找出来的绝大部分信息都是基于EndNote X9,所以这是自己摸索出来的方法 [这篇文章在CSDN上也发了一次,地址:https://blog.csdn.net/2301_79112268/ ...

  3. 从装水瓶到接雨水:一道经典动态规划问题的深度解析|LeetCode 42 接雨水

    LeetCode 42 接雨水 点此看全部题解 LeetCode必刷100题:一份来自面试官的算法地图(题解持续更新中) 生活中的算法 你有没有注意过,很多户外运动的水壶都有不规则的凹凸形状?这些凹凸 ...

  4. LeetCode必刷100题:一份来自面试官的算法地图(题解持续更新中)

    大家好,我是忍者程序员.上一篇文章我们讨论了如何科学地刷题,今天我要带大家深入了解这100道精选题目背后的分类逻辑.作为一名面试官,我希望通过这篇文章,为大家绘制一张完整的算法知识地图. 为什么要按类 ...

  5. Q: USB无线网卡搜不到路由器WiFi,但也能搜索到少部分信号。

    原因分析:一般在路由器的配置的无线信道是自动,路由器的2.4G频段有13个左右交叠的信道.由于USB无线网卡的设置信道区间可能不在无线信道范围内,导致无线网卡搜索不到对应wifi. 解决问题:鼠标右键 ...

  6. kubernets学习笔记二

    Kubernetes部署"容器化应用" Kubernetes整体架构 何为"容器化应用"? 通俗点来说,就是你把一个程序放在docker里部署,这个docker ...

  7. .NET周刊【2月第2期 2025-02-09】

    国内文章 开箱即用的.NET MAUI组件库 V-Control 发布了! https://www.cnblogs.com/jevonsflash/p/18701494 文章介绍了V-Control, ...

  8. js中的模糊搜索( 正则表达式)

    此案例在vue中实现 搜索设备ID示例 <input type="text" name="" placeholder="搜索设备ID" ...

  9. SSM:Spring整合Mybatis时,连接池和SQLSessionFactory的联系!

  10. 数据库离程序员有多远 - cnblogs救园行动感想

    这两周,我参与了博客园的"2024救园行动",成了终身会员.说实话,当初报名的时候,我心里还挺兴奋的,想着这下能和不少老朋友在这个社区里再次相聚.毕竟,在数据库行业摸爬滚打了这么多 ...