iComet

iComet 是一个使用 C++ 语言开发的支持百万并发连接的 comet/push 服务器, 支持百万级并发连接, 内存占用少, 性能优越. 可用于移动 App 的 Push Server(消息推送服务器), 或者用于 Web Push(Web 服务器推). 用于 Web Push 时, 支持的浏览器和操作系统平台包括: Safari(iOS, Mac), Firefox/Chrome(Windows, Mac), IE6+.

项目主页: https://github.com/ideawu/icomet
官方QQ群: 389083972

开源中国社区(oschina) 推荐项目

iComet 荣获开源中国社区(oschina) 推荐项目:

iComet 在 Web 系统和移动应用系统中的角色

iComet 的工作流程

icomet 分布式

icomet 本身没有分布式方面的工具. 我可以说一个思路: 1. 部署多台 icomet-server 实例. 2. 用户调用 sign 申请通道时, 根据 uid 哈希到其中一台. 3. 当往用户推送消息时, 根据uid哈希推送到他所在的那一台icomet-server上.

如果你可以开发, 那便写程序订阅 psub 接口, 在一个中心节点保存uid和icomet-server的对应关系(路由表).

支持百万并发连接 C1000K

需要两个步骤:

相关文章:

各种 Comet 技术优缺点对比
HTTP 长连接技术 Comet
长连接技术的应用

Views: 40588

5 Responses to "iComet"

  • How to keep alive ping by use icomet? Reply
  • 你好,我当前项目使用xmpp做推送,对icomet很感兴趣,可以交个朋友吗? Reply
  • virtual const std::vector<std::string>* request(const std::string &cmd) = 0;,这个接口用来做什么的,能否告诉我哪里有资料关于它的用法,或者如何使用,再或者Deamo来一个呗 Reply
  • hi,
    因为项目中要用到博主的icomet,看了git上的文档后有些东西还是不明白,所以想请教一下博主,
    icomet里面sub和poll、iframe等的区别,pub和push区别,sub之前必须sign吗?sign需要带哪些参数,还有token该如何使用?

    十分抱歉问这么多问题,希望您不忙的时候解答一下,谢谢 Reply
    @zhouwei: 作者不回答你应该就是因为你没有深入去读源码吧。pub和push都是发送,但前者只能支持json数据,后者发送的是raw content。根据需要可以把验证的过程放在sub请求中,后面带上一个token,服务端用同样的加密算法做一次验证。不知道对不对,希望博主指正。
    另外,既然是一个希望大家拿来用的东西,还是希望博主能提供更完整的文档。谢谢 Reply

Leave a Comment