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

HTTP、WebSocket、SSE 对比

特性HTTPWebSocketSSE (Server-Sent Events)
通信模式请求-响应(单向)全双工双向通信服务器到客户端的单向通信
连接方式短连接(默认)长连接长连接
协议基础TCP(HTTP/1.1, HTTP/2)基于HTTP升级基于HTTP
数据格式任意格式二进制或文本文本(text/event-stream
实时性低(依赖轮询)高(毫秒级延迟)中(服务器主动推送)
浏览器支持所有浏览器现代浏览器现代浏览器(IE除外)

优缺点对比

协议优点缺点
HTTP✅ 简单易用
✅ 无状态易扩展
✅ 缓存支持
❌ 实时性差
❌ 频繁请求开销大
WebSocket✅ 全双工实时通信
✅ 低延迟
✅ 高效(减少头开销)
❌ 实现复杂
❌ 无自动重连机制
SSE✅ 自动重连
✅ 简单易用(HTTP基础)
✅ 轻量级推送
❌ 单向通信(服务器→客户端)
❌ 文本格式限制

应用场景

  • HTTP:常规API请求、静态资源加载、表单提交
  • WebSocket:在线聊天、实时游戏、协同编辑
  • SSE:实时通知、股票行情推送、新闻更新

简易Java案例

1. HTTP Server (Java Servlet)
@WebServlet("/http")
public class HttpServletDemo extends HttpServlet {@Overrideprotected void doGet(HttpServletRequest req, HttpServletResponse resp) throws IOException {resp.setContentType("text/plain");resp.getWriter().write("HTTP Response: " + new Date());}
}
# 测试命令
curl http://localhost:8080/http
2. WebSocket Server (Jakarta EE)
@ServerEndpoint("/ws")
public class WebSocketServer {@OnOpenpublic void onOpen(Session session) {System.out.println("WebSocket connected");}@OnMessagepublic void onMessage(String message, Session session) {try {session.getBasicRemote().sendText("Echo: " + message);} catch (IOException e) {e.printStackTrace();}}
}
<!-- 客户端测试 -->
<script>const ws = new WebSocket("ws://localhost:8080/ws");ws.onmessage = (e) => console.log("Received:", e.data);ws.send("Hello WebSocket!");
</script>
3. SSE Server (Java Servlet)
@WebServlet("/sse")
public class SseServlet extends HttpServlet {@Overrideprotected void doGet(HttpServletRequest req, HttpServletResponse resp) throws IOException {resp.setContentType("text/event-stream");resp.setCharacterEncoding("UTF-8");PrintWriter writer = resp.getWriter();for (int i = 0; i < 5; i++) {writer.write("data: SSE Message " + i + "\n\n");writer.flush();Thread.sleep(1000);}}
}
// 客户端测试
const es = new EventSource("/sse");
es.onmessage = e => console.log(e.data);

关键区别总结

  1. 通信方向

    • HTTP:客户端发起请求
    • WebSocket:双向实时通信
    • SSE:服务器单向推送
  2. 连接生命周期

    • HTTP:请求后立即关闭(Keep-Alive可复用)
    • WebSocket/SSE:持久化长连接
  3. 协议开销

    • WebSocket建立后头部开销最小(2-10字节)
    • HTTP每次请求携带完整头部
    • SSE基于HTTP,但连接复用减少开销
  4. 重连机制

    • SSE内置自动重连
    • WebSocket需手动实现
    • HTTP每次请求都是新连接
  5. 数据格式

    • WebSocket支持二进制(适合传输文件)
    • SSE仅文本(需Base64编码传输二进制)

技术选型建议

  • 需要双向实时交互(如聊天室)→ WebSocket
  • 只需服务器推送(如通知系统)→ SSE(更简单)
  • 传统请求/响应场景 → HTTP
  • 需要兼容旧浏览器 → HTTP长轮询 + SSE降级方案

相关文章:

  • CNN卷积网络:让计算机拥有“火眼金睛“(superior哥AI系列第4期)
  • 打卡day43
  • 秋招Day12 - 计算机网络 - UDP
  • 05.MySQL表的约束
  • 如何区分虚拟货币诈骗与经营失败?
  • STM32G4 电机外设篇(四)DAC输出电流波形 + CAN通讯
  • Vue-3-前端框架Vue基础入门之VSCode开发环境配置和Tomcat部署Vue项目
  • paoxiaomo的XCPC算法竞赛训练经验
  • C++中实现随机数(超详细!​​​​​)
  • 黑马程序员C++核心编程笔记--4 类和对象--多态
  • 1.文件操作相关的库
  • Java Netty 中处理粘包和半包问题的解决方案 | TCP消息完整性校验(XOR )
  • 基于GPT-SoVITS-v4-TTS的音频文本推理,流式生成
  • SOC-ESP32S3部分:25-HTTP请求
  • 移动AI神器GPT Mobile:多模型自由切换
  • 基于SpringBoot运动会管理系统设计和实现(源码+文档+部署讲解)
  • 抛砖引玉:RadarDet4D,NuScenes数据集Radar模态目标检测第二名(即将开源)
  • 道路目标检测和分类数据集
  • 神经网络中的梯度消失与梯度爆炸
  • TC3xx学习笔记-启动过程详解(一)
  • wordpress添加首页友情链接/北京网站优化企业
  • 网站建设的快乐/seo包括什么
  • 朝阳网站建设是什么/香港域名注册网站
  • 制作一个网站怎么做/网站买卖
  • 网站建设首页突出什么/整站优化关键词推广
  • 上海牛巨微seo优化/seo 论坛