centrifuge: 实时消息服务

构建实时消息服务的方案有很多种,centrifuge是用go 实现的一种,功能确实不错,基于Websocket SockJS 通信。

特点

  • 性能做了优化,可与数千个客户端连接进行低延迟通信
  • 使用Redis PUB / SUB扩展到许多节点,内置Redis分片、HA Sentinel
  • 双向异步消息通信,RPC调用
  • 使用频道(房间)概念,向所有频道订户广播消息
  • 频道的在线信息(显示频道中的所有活动客户端)
  • 频道的历史信息(发布到频道的最后消息)
  • 加入/离开频道的活动(客户上线/下线)
  • 网络断开后信道的消息恢复机制

网络结构

centrifuge 拓扑结构

centrifuge 项目地址 https://github.com/centrifugal/centrifuge 22

Relative Articles