0

0

如何使用Golang开发新闻推送系统_Golang消息推送与数据存储项目

P粉602998670

P粉602998670

发布时间:2026-02-08 11:57:32

|

788人浏览过

|

来源于php中文网

原创

WebSocket推送必须解耦连接管理与消息触发,需用全局广播channel和独立goroutine分发,避免阻塞;连接池、标签路由、ACK机制及离线补偿等保障到达率。

如何使用golang开发新闻推送系统_golang消息推送与数据存储项目

WebSocket 推送必须解耦连接管理与消息触发

很多人卡在“连上了却推不出消息”,根本原因是把 conn.WriteMessage() 写死在 WebSocket handler 里——那只是回显,不是服务端主动推送。真正的新闻推送系统,得让 HTTP 接口、定时任务、数据库变更监听等外部事件,能随时把消息塞进广播通道。

  • 必须用一个全局带缓冲的 broadcast channel(如 make(chan []byte, 100)),避免单个客户端写失败导致整个广播阻塞
  • 单独起一个 goroutine 持续从 broadcast 读取消息,再遍历 clients map[uint64]*websocket.Conn 分发——*websocket.Conn 非并发安全,绝不能在 HTTP handler 里直接遍历写
  • upgrader.CheckOrigin 开发时可临时设为 return true,但上线前务必校验 Origin 头,否则 Nginx 反向代理后可能因头丢失而握手失败

短轮询适合小规模新闻站,但缓存和清空逻辑不能省

如果你的新闻后台只有几十个编辑或百来个内部审核员看“新稿件待审”,用短轮询比搞 WebSocket 更快上线、更稳、兼容 IE11。但它不是“查完就返回”,而是“查完要标记已读+防重复”。

  • messages 绝不能存在内存 map[string][]string 里——进程重启全丢;必须用 Redis 或带 TTL 的本地缓存(如 freecache.Cache
  • 每次请求返回后,必须调用 redis.DEL("user:123:notifications")cache.Delete("user:123:notifications"),否则下一次拉取还是旧消息
  • 别用 json.NewEncoder(w).Encode() 直接吐 JSON;短轮询响应是普通 HTTP,格式自由,但要加 Cache-Control: no-cache 头防浏览器缓存

消息落库必须异步 + 带状态回执,否则“发了=收到”是假象

新闻类推送对到达率敏感:一条突发快讯没触达,就是漏报。Go 系统里“写完 DB 就 return”不等于用户收到了,尤其移动端网络不稳定。

  • 消息进入系统后,先异步写入 WAL 日志或 BadgerDB(非阻塞),再推送到 WebSocket 连接池;同步写 MySQL 会拖慢吞吐
  • 客户端收到后必须主动上报 ack?msg_id=abc123,服务端用 sync.Map 存未确认 ID,30 秒超时未 ack 则重试(最多 2 次,指数退避)
  • 重试失败的消息,转存到 Kafka topic news-offline,由离线补偿服务兜底推送 App Push 或短信

标签路由不能硬编码,动态订阅关系要用读写锁保护

新闻系统要支持“只推科技板块”“屏蔽娱乐频道”,就得让用户能随时订阅/退订标签。但直接在 map 上增删订阅关系,容易因并发导致数据错乱或死锁。

图想浪漫
图想浪漫

AI驱动的智能图片编辑解压娱乐站

下载

立即学习go语言免费学习笔记(深入)”;

  • sync.RWMutex 包裹 subscriptions map[string][]*Client,增删时用 Lock(),分发时用 RUnlock()——千万别在锁里做 DB 查询或 HTTP 调用
  • 写入消息时按标签哈希到 shard(如 shardID := int(hash(tag)) % 64),每个 shard 有独立 chan *Message 和消费 goroutine,避免所有消息挤在一个 channel 里排队
  • 退订操作不要立刻从 map 删除,先标记 status: "pending_unsub",等当前 shard 消费完该用户最后一批消息再清理,防止漏推

真正难的从来不是“怎么把消息发出去”,而是“怎么确保它只发给该发的人、发完有人认账、发断了还能捡回来”。这些点不埋进代码里,上线后半夜报警的永远是推送服务。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
golang如何定义变量
golang如何定义变量

golang定义变量的方法:1、声明变量并赋予初始值“var age int =值”;2、声明变量但不赋初始值“var age int”;3、使用短变量声明“age :=值”等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

184

2024.02.23

golang有哪些数据转换方法
golang有哪些数据转换方法

golang数据转换方法:1、类型转换操作符;2、类型断言;3、字符串和数字之间的转换;4、JSON序列化和反序列化;5、使用标准库进行数据转换;6、使用第三方库进行数据转换;7、自定义数据转换函数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

232

2024.02.23

golang常用库有哪些
golang常用库有哪些

golang常用库有:1、标准库;2、字符串处理库;3、网络库;4、加密库;5、压缩库;6、xml和json解析库;7、日期和时间库;8、数据库操作库;9、文件操作库;10、图像处理库。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

344

2024.02.23

golang和python的区别是什么
golang和python的区别是什么

golang和python的区别是:1、golang是一种编译型语言,而python是一种解释型语言;2、golang天生支持并发编程,而python对并发与并行的支持相对较弱等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

211

2024.03.05

golang是免费的吗
golang是免费的吗

golang是免费的。golang是google开发的一种静态强类型、编译型、并发型,并具有垃圾回收功能的开源编程语言,采用bsd开源协议。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

399

2024.05.21

golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

282

2025.06.09

golang相关判断方法
golang相关判断方法

本专题整合了golang相关判断方法,想了解更详细的相关内容,请阅读下面的文章。

196

2025.06.10

golang数组使用方法
golang数组使用方法

本专题整合了golang数组用法,想了解更多的相关内容,请阅读专题下面的文章。

681

2025.06.17

Golang处理数据库错误教程合集
Golang处理数据库错误教程合集

本专题整合了Golang数据库错误处理方法、技巧、管理策略相关内容,阅读专题下面的文章了解更多详细内容。

67

2026.02.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 2.2万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 824人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号