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