V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
itIsUnbelievable
V2EX  ›  问与答

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

  •  
  •   itIsUnbelievable · 2020-02-12 14:19:20 +08:00 · 1507 次点击
    这是一个创建于 1751 天前的主题,其中的信息可能已经有所发展或是发生改变。

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

    4 条回复    2020-02-12 16:58:44 +08:00
    opengps
        1
    opengps  
       2020-02-12 14:27:26 +08:00   ❤️ 1
    websocket 是用作网页聊天的,app 聊天更适合用 socket。
    使用什么语言实现严格来说并不太依赖语言,只是有些语言的 socket 处理性能表现会更好。
    这个万人聊天的难点在于服务端的集群扩容处理。1 万连接处理得当还可以单服务器承载,但是带上其他逻辑就不一定能用单机支撑了,需要考虑分布式和集群,共享缓存,各组件解耦等因素。很多人都是缺少这个经验,建议参考下云架构的思路(用户多了只需要加机器)
    itIsUnbelievable
        2
    itIsUnbelievable  
    OP
       2020-02-12 15:04:25 +08:00
    @opengps 非常感谢,现在好像还不到万人那个程度,我想先把功能实现出来。我使用的是 django,我查了一下,django 好像不支持 WebSocket,不过好像有个 channels 扩展框架好像能实现 websocket,它好像是不用 wsgi 而用 asgi。不知道能不能用?感觉没有了方向。
    izoabr
        3
    izoabr  
       2020-02-12 15:08:50 +08:00
    直接 redis 就行吧,客户端连 redis 的 websocket,然后 Python 去订阅队列处理逻辑呗。
    dcalsky
        4
    dcalsky  
       2020-02-12 16:58:44 +08:00   ❤️ 1
    @itIsUnbelievable 这个库没问题的,万人不万人等你业务量真正上来了再说呗,websocket 真不是你的瓶颈。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2564 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 22ms · UTC 15:54 · PVG 23:54 · LAX 07:54 · JFK 10:54
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.