GolangNote

Golang笔记

centrifuge: 实时消息服务

Permalink

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

特点

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

网络结构

centrifuge 拓扑结构

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

本文网址: https://golangnote.com/topic/238.html 转摘请注明来源

Related articles

Golang http IPv4/IPv6 服务

Golang 的网络服务,如果不指定IPv4 或 IPv6,如果VPS 同时支持 IPv4 和 IPv6,`net.Listen()` 只会监听 IPv6 地址。但这不影响客户端使用 IPv4 地址来访问。...

Write a Comment to "centrifuge: 实时消息服务"

Submit Comment Login
Based on Golang + fastHTTP + sdb | go1.20 Processed in 0ms