群聊天系统,高吞吐量,高转发量,后端什么架构?

2013-12-06 22:12:27 +08:00
 fanghui
群聊天系统,高吞吐量,高转发量,后端什么架构?比如一个群1000个人在聊天,共20万个这样的群,正在此系统活动。目前没有这方面的经验,还请v2er多多提看法和意见
12658 次点击
所在节点    问与答
18 条回复
ejin
2013-12-06 22:34:54 +08:00
yy一个频道几万人在线。还有视频。太牛擦了
czheo
2013-12-06 22:38:28 +08:00
IRC
victor
2013-12-06 23:38:30 +08:00
xmpp
plucury
2013-12-06 23:57:09 +08:00
如果只是群聊天可以考虑用发布-订阅的协议来做。比如MQTT,用户进入群就是订阅了topic,然后发言就向这个topic发消息,所有订阅该topic的人都能收到。具体到使用的技术,我们现在用netty实现了类似的应用,大概每台服务器支持了150w个用户这样(应该还能提升)。
013231
2013-12-07 00:03:34 +08:00
binux
2013-12-07 00:08:29 +08:00
20w*1000人在线,同时在线2亿人。。。QQ就是个渣渣啊
9hills
2013-12-07 00:39:09 +08:00
2亿人同时在线的系统。。lz没有经验还是不要做了,这个最少值2亿
lvye
2013-12-07 00:46:22 +08:00
架构做出来,验证也是个问题。目前估计只有腾讯有这个经验了。
Numbcoder
2013-12-07 00:58:34 +08:00
@binux
一个群1000个人在聊天,共20万个这样的群, 一个人有没有可能在多个群,那么这样的话就不能简单 20w*1000 这么算了

其实最重要的是要估算同时在线人数和消息量吧
binux
2013-12-07 01:12:54 +08:00
@Numbcoder 一个人在多个群,那也是多个链接啊,对于服务器来说是一样的啊
Numbcoder
2013-12-07 01:24:05 +08:00
@binux 怎么会是多个链接,必须是一条链接!
zorceta
2013-12-07 07:34:09 +08:00
@Numbcoder 感觉“信道”这个说法比较合适……我就随口一说
xujialiang
2013-12-07 08:38:22 +08:00
消息队列吧。可路由转发不同服务器,貌似公司的报文服务就是这么干的
fanghui
2013-12-07 09:27:17 +08:00
目前,消息大小限值在255个字符之内,不限制一个人在多个群。
akira
2013-12-07 09:58:36 +08:00
估计没几个人有这种经验。

不过大规模的使用内存数据库 和 消息队列 应该跑不掉的了。
yeelone
2013-12-07 10:38:47 +08:00
之前做聊天室时,用的是redis的 subpub 功能,用户订阅了频道,在同频道中的其它用户发布消息都由redis 来做发布,开发起来也简单。不过20w*1000人在线 ~~~ 这里面要考虑的东西还要更复杂
binux
2013-12-07 11:42:30 +08:00
@Numbcoder 需要处理和转发的事件量是一样的啊
Numbcoder
2013-12-07 20:28:03 +08:00
做过百万级别同时在线的案例。lz 这个可能比我的大。
给 lz 几个建议:
1. 选好协议。从你的应用场景来看,XMPP 或 MQTT 比较合适,群组功能是典型的 PubSub 应用场景。如果有移动端的话,MQTT 稍微好点。
2. 服务端语言选型要慎重。erlang,golang 或许比较合适,java 的话可以试试 netty。
3. 还是要先做好充分的调研,同时在线人数(群组数量真不太重要,在 PubSub 里就是订阅个 topic 而已),每秒钟的消息量,这两个指标比较重要。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/92125

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX