支持即时通讯,站内/系统消息,消息中台,物联网通讯,音视频信令,直播弹幕,客服系统,AI通讯,即时社区等场景。
(注意:此项目是一个通用的底层即时通讯服务,上层需要对接自己的具体业务系统(通过webhook和datasource机制非常轻松与自己业务系统对接),此项目核心点主要维护大量客户端的长连接,并根据第三方业务系统配置的投递消息规则进行消息投递。)
本项目需要在go1.20.0或以上环境编译
- 完全自研:自研消息数据库,消息分区永久存储,自研二进制协议(支持自定义),重写Go底层网络库,无缝支持TCP和websocket。
- 性能强劲:单机支持百万用户同时在线,单机16w/秒消息(包括DB操作)吞吐量,一个频道支持万人同时订阅。
- 零依赖:没有依赖任何第三方组件,部署简单,一条命令即可启动
- 安全:消息通道和消息内容全程加密,防中间人攻击和窜改消息内容。
- 扩展性强:采用频道设计理念,目前支持群组频道,点对点频道,后续可以根据自己业务自定义频道可实现机器人频道,客服频道等等。
- 支持自定义消息
- 支持订阅/发布者模式
- 支持个人/群聊/客服频道
- 支持频道黑明单
- 支持频道白名单
- 支持消息永久漫游,换设备登录,消息不丢失
- 支持在线状态,支持同账号多设备同时在线
- 支持多设备消息实时同步
- 支持用户最近会话列表服务端维护
- 支持离线指令接口
- 支持Webhook,轻松对接自己的业务系统
- 支持Datasource,无缝对接自己的业务系统数据源
- 支持Websocket连接
- 支持TLS 1.3
- 支持Windows系统(仅开发用)
- 支持分布式
查询系统信息: http://127.0.0.1:5001/varz
端口解释:
5001: api端口
5100: tcp长连接端口
5200: websocket长连接端口
总体架构图
业务系统对接
Webhook对接图
- 群频道支持
- 个人频道支持
- 消息永久存储
- 离线消息推送支持
- 最近会话维护
- 群频道支持
- 个人频道支持
- 离线消息推送支持
- mqtt协议支持(待开发)
- 支持发布与订阅
- 支持临时指令消息投递
-
临时消息投递
-
临时订阅者支持
-
客服频道支持
-
消息支持投递给第三方服务器
-
第三方服务器可决定分配指定的订阅者成组投递
一直致力于即时通讯的研发,需要您的鼓励,如果您觉得本项目对您有帮助,欢迎点个star,您的支持是我最大的动力。
IMServer is licensed under the Apache License 2.0.