请问用 Python 实现一个 app 端的万人聊天系统可行吗?

2020-02-12 14:19:20 +08:00
 itIsUnbelievable

主要是点对点聊天和群聊功能。我搜了下实现聊天系统一般是用 websocket 吧? 我想实现 boss 聘的那种聊天功能,发送语音和视频是不是不太好弄?我看 github 上都是用 python 实现的简单聊天系统,是不是一般都不用 python 实现聊天系统,毕竟多线程是个短板。我想了解一下要实现这种聊天系统的难点在哪?用 python 可不可行? 万分感谢!!!

1352 次点击
所在节点    问与答
4 条回复
opengps
2020-02-12 14:27:26 +08:00
websocket 是用作网页聊天的,app 聊天更适合用 socket。
使用什么语言实现严格来说并不太依赖语言,只是有些语言的 socket 处理性能表现会更好。
这个万人聊天的难点在于服务端的集群扩容处理。1 万连接处理得当还可以单服务器承载,但是带上其他逻辑就不一定能用单机支撑了,需要考虑分布式和集群,共享缓存,各组件解耦等因素。很多人都是缺少这个经验,建议参考下云架构的思路(用户多了只需要加机器)
itIsUnbelievable
2020-02-12 15:04:25 +08:00
@opengps 非常感谢,现在好像还不到万人那个程度,我想先把功能实现出来。我使用的是 django,我查了一下,django 好像不支持 WebSocket,不过好像有个 channels 扩展框架好像能实现 websocket,它好像是不用 wsgi 而用 asgi。不知道能不能用?感觉没有了方向。
izoabr
2020-02-12 15:08:50 +08:00
直接 redis 就行吧,客户端连 redis 的 websocket,然后 Python 去订阅队列处理逻辑呗。
dcalsky
2020-02-12 16:58:44 +08:00
@itIsUnbelievable 这个库没问题的,万人不万人等你业务量真正上来了再说呗,websocket 真不是你的瓶颈。

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

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

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

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

© 2021 V2EX