构建实时消息服务的方案有很多种,centrifuge是用go 实现的一种,功能确实不错,基于Websocket SockJS 通信。
特点
- 性能做了优化,可与数千个客户端连接进行低延迟通信
- 使用Redis PUB / SUB扩展到许多节点,内置Redis分片、HA Sentinel
- 双向异步消息通信,RPC调用
- 使用频道(房间)概念,向所有频道订户广播消息
- 频道的在线信息(显示频道中的所有活动客户端)
- 频道的历史信息(发布到频道的最后消息)
- 加入/离开频道的活动(客户上线/下线)
- 网络断开后信道的消息恢复机制
网络结构
centrifuge 项目地址 https://github.com/centrifugal/centrifuge
本文网址: https://golangnote.com/topic/238.html 转摘请注明来源