centrifuge: 实时消息服务

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

特点

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

网络结构

centrifuge 拓扑结构

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

Relative Articles
本文网址: https://www.golangnote.com/topic/238.html (转载注明出处)
关于GolangNote:记录在工作中使用golang 遇到、面临的相关问题及解决方法。如果你在这里获得一些知识或信息,解决你的编程问题,请考虑捐赠给不幸的人或者你喜欢的慈善机构,除捐赠外,种植树木、志愿服务或减少排碳的行为也很有益处。