centrifuge: 实时消息服务
🕔 Wed, 14 Nov 2018 by GolangNote
构建实时消息服务的方案有很多种,centrifuge是用go 实现的一种,功能确实不错,基于Websocket SockJS 通信。
特点
- 性能做了优化,可与数千个客户端连接进行低延迟通信
- 使用Redis PUB / SUB扩展到许多节点,内置Redis分片、HA Sentinel
- 双向异步消息通信,RPC调用
- 使用频道(房间)概念,向所有频道订户广播消息
- 频道的在线信息(显示频道中的所有活动客户端)
- 频道的历史信息(发布到频道的最后消息)
- 加入/离开频道的活动(客户上线/下线)
- 网络断开后信道的消息恢复机制
网络结构
centrifuge 项目地址 https://github.com/centrifugal/centrifuge 69
本文网址: https://golangnote.com/topic/238.html (转载注明出处)
关于GolangNote:记录在工作中使用golang 遇到、面临的相关问题及解决方法。如果你在这里获得一些知识或信息,解决你的编程问题,请考虑捐赠给不幸的人或者你喜欢的慈善机构,除捐赠外,种植树木、志愿服务或减少排碳的行为也很有益处。如果你有任何问题可以在下面 留言
Be the first to comment!
Relative Articles
Recent Go Articles
- Golang 把cookie 字符串解析为cookie 结构
- Golang 计算字符串中包含某个或某些字符集的个数
- 使用Golang 对文件增删写读操作备忘
- Go Modules 使用备忘
- 使用Golang 简单删除图片exif 信息
- 谷歌翻译的 golang 库推荐
- Go 1.13.2 与1.13.3 紧急更新
- golang 人脸检测识别库
- Go build 错误 “stackcheck redeclared in this block previous declaration”的解决方法
- Golang phantomjs 动态代理实现
- Golang chrome debug protocol 库推荐
- Golang 随机打乱数组/Slice
- Golang sync.WaitGroup 的 Wait 超时处理
- Golang实现简单的Socks5代理
- Golang 用snappy + Base64 简单压缩加密进行网络传输
- Golang http IPv4/IPv6 服务
- golang 全角半角相互转换
- 在自己的网站部署TLS 1.3
- Golang 实现/打印菜单树
- Golang telegram 机器人小试
Top Go Articles
- Golang 字符串毫秒转时间格式
- goji + mysql 例子
- 用Go net 工具包获取DNS 信息
- 推荐几款开源免费的用golang写的论坛程序
- GoLang 获取变量类型
- Golang Web 自动安装、更新Let’s Encrypt 免费证书
- golang Selenium WebDriver 使用记录
- Golang Leveldb 基本使用的例子
- go 实现图片服务器缓存
- Golang io.ReadCloser 和[]byte 相互转化的方法
- Golang WebAssembly 了解一下
- groupcache 使用入门
- Golang 随机打乱数组/Slice
- GoLang 遍历目录的不同方法
- Golang byte to string 的方法实践
- Golang 合并byte 的性能比较
- GoLang 实现python timedelta 函数功能
- golang leveldb 区间查找
- Golang http.Post 用最小的内存发送大文件
- 用Supervisor 守护Golang 应用进程的配置示例