当前位置:首页 > 文章列表 > Golang > Go教程 > Golang怎么实现SSE推送_Golang如何用HTTP流式响应实现服务端事件推送【教程】

Golang怎么实现SSE推送_Golang如何用HTTP流式响应实现服务端事件推送【教程】

2026-05-03 20:15:44 0浏览 收藏

今天golang学习网给大家带来了《Golang怎么实现SSE推送_Golang如何用HTTP流式响应实现服务端事件推送【教程】》,其中涉及到的知识点包括等等,无论你是小白还是老手,都适合看一看哦~有好的建议也欢迎大家在评论留言,若是看完有所收获,也希望大家能多多点赞支持呀!一起加油学习~

Go原生HTTP服务器支持SSE,需设置Content-Type、Cache-Control、Connection响应头,事件格式为data: xxx\n\n,每次发送后必须调用http.Flusher.Flush(),并监听客户端断连及时退出goroutine。

Golang怎么实现SSE推送_Golang如何用HTTP流式响应实现服务端事件推送【教程】

Go 原生 HTTP 服务器完全支持 SSE(Server-Sent Events),不需要额外框架,关键在于正确设置响应头、保持连接不关闭、按规范输出事件流数据——否则浏览器会直接关闭连接或解析失败。

必须设置的三个响应头

SSE 要求服务端明确声明内容类型和缓存策略,否则 Chrome/Firefox 会拒绝解析为事件流:

  • Content-Type: text/event-stream —— 缺少这个,EventSource 实例状态永远卡在 connecting
  • Cache-Control: no-cache —— 浏览器可能缓存初始响应,导致后续事件不触发 message 事件
  • Connection: keep-alive —— 显式声明长连接,避免代理(如 Nginx)或负载均衡器中途断连

示例写法:

func sseHandler(w http.ResponseWriter, r *http.Request) {
    w.Header().Set("Content-Type", "text/event-stream")
    w.Header().Set("Cache-Control", "no-cache")
    w.Header().Set("Connection", "keep-alive")
    // 后续写入事件...
}

每次事件必须以 data: 开头并以双换行结尾

SSE 协议对格式极其敏感:每条消息必须以 data: 开头,末尾必须是两个连续的 \n(即 \n\n),中间不能有空格或多余字符。漏掉一个换行,整个事件就会被丢弃。

  • ✅ 正确:data: hello\n\n
  • ❌ 错误:data: hello\n(少一个 \n
  • ❌ 错误:data:hello\n\n: 后缺空格,部分浏览器不认)
  • ❌ 错误:data: hello\r\n\r\n(Windows 换行符,应统一用 \n

推荐封装成辅助函数避免手误:

func sendEvent(w io.Writer, msg string) {
    fmt.Fprintf(w, "data: %s\n\n", msg)
    w.(http.Flusher).Flush() // 强制刷出缓冲
}

必须调用 Flush(),否则事件永远发不出去

Go 的 http.ResponseWriter 默认带缓冲,不主动 Flush(),数据会一直卡在内存里。SSE 是流式响应,每条事件都得立刻送达客户端。

  • 必须把 w 断言为 http.Flusher 并调用 Flush()
  • 不能只依赖 fmt.Printlnw.Write —— 它们不触发刷新
  • 如果用了 bufio.Writer 包裹,要确保它也 flush,但更推荐直接用原生 Flusher

典型错误写法:

// ❌ 不会实时推送
fmt.Fprint(w, "data: ping\n\n")
<p>// ✅ 正确(需先断言)
if f, ok := w.(http.Flusher); ok {
fmt.Fprint(w, "data: ping\n\n")
f.Flush()
}</p>

客户端断连后,服务端 goroutine 必须能及时退出

每个 SSE 连接对应一个长生命周期的 goroutine。如果客户端关掉页面或网络中断,而服务端还在往已关闭的连接里写数据,会触发 write: broken pipe 错误,并且 goroutine 泄露。

  • 务必检查 w.WriteFlush() 的返回值,遇到 io.ErrClosedPipenet.ErrClosed 就立即 return
  • 不要用 time.Ticker 无条件推送,应在每次写之前判断连接是否还活跃
  • 可配合 r.Context().Done() 监听请求取消(比如客户端关闭连接时 context 会被 cancel)

简单防护示例:

for {
    select {
    case <p>真正难的不是写出第一行 <code>data:</code>,而是让连接在各种网络抖动、代理转发、浏览器重连机制下稳定维持——header、换行、flush、错误回收,四者缺一不可。</p><p>今天关于《Golang怎么实现SSE推送_Golang如何用HTTP流式响应实现服务端事件推送【教程】》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!</p>
1立方米等于多少升_立方米和升怎么换算1立方米等于多少升_立方米和升怎么换算
上一篇
1立方米等于多少升_立方米和升怎么换算
12306怎么修改手机号绑定 12306账号维护方法【技巧】
下一篇
12306怎么修改手机号绑定 12306账号维护方法【技巧】
查看更多
最新文章
资料下载
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    543次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    516次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    500次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    485次学习
查看更多
AI推荐
  • ChatExcel酷表:告别Excel难题,北大团队AI助手助您轻松处理数据
    ChatExcel酷表
    ChatExcel酷表是由北京大学团队打造的Excel聊天机器人,用自然语言操控表格,简化数据处理,告别繁琐操作,提升工作效率!适用于学生、上班族及政府人员。
    4452次使用
  • Any绘本:开源免费AI绘本创作工具深度解析
    Any绘本
    探索Any绘本(anypicturebook.com/zh),一款开源免费的AI绘本创作工具,基于Google Gemini与Flux AI模型,让您轻松创作个性化绘本。适用于家庭、教育、创作等多种场景,零门槛,高自由度,技术透明,本地可控。
    4803次使用
  • 可赞AI:AI驱动办公可视化智能工具,一键高效生成文档图表脑图
    可赞AI
    可赞AI,AI驱动的办公可视化智能工具,助您轻松实现文本与可视化元素高效转化。无论是智能文档生成、多格式文本解析,还是一键生成专业图表、脑图、知识卡片,可赞AI都能让信息处理更清晰高效。覆盖数据汇报、会议纪要、内容营销等全场景,大幅提升办公效率,降低专业门槛,是您提升工作效率的得力助手。
    4683次使用
  • 星月写作:AI网文创作神器,助力爆款小说速成
    星月写作
    星月写作是国内首款聚焦中文网络小说创作的AI辅助工具,解决网文作者从构思到变现的全流程痛点。AI扫榜、专属模板、全链路适配,助力新人快速上手,资深作者效率倍增。
    6475次使用
  • MagicLight.ai:叙事驱动AI动画视频创作平台 | 高效生成专业级故事动画
    MagicLight
    MagicLight.ai是全球首款叙事驱动型AI动画视频创作平台,专注于解决从故事想法到完整动画的全流程痛点。它通过自研AI模型,保障角色、风格、场景高度一致性,让零动画经验者也能高效产出专业级叙事内容。广泛适用于独立创作者、动画工作室、教育机构及企业营销,助您轻松实现创意落地与商业化。
    5055次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码