V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐学习书目
Learn Python the Hard Way
Python Sites
PyPI - Python Package Index
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
zzcflying
V2EX  ›  Python

tornado long polling 如何保存要返回的 response 对象

  •  
  •   zzcflying ·
    zhenchaozhu · 2015-06-12 11:40:47 +08:00 · 2739 次点击
    这是一个创建于 3482 天前的主题,其中的信息可能已经有所发展或是发生改变。

    在tornado的demo中发现是用数组对象来保存response的,但是要是启动多个进程部署tornado的话,那应该怎么保存长连接的response对象呢。
    我尝试使用redis来保存发现不可行。
    求教各位大神有好的解决方案吗。

    5 条回复    2015-06-12 12:26:05 +08:00
    realityone
        1
    realityone  
       2015-06-12 11:45:14 +08:00
    。。没重度用过 tornado,pickle 后再保存看看
    ipconfiger
        2
    ipconfiger  
       2015-06-12 11:48:14 +08:00
    还是存在本地的字典里,每次请求给分配一个id,然后redis里存response的id,回调的时候只有在本地字典里有这个id的进程返回就ok了
    zzcflying
        3
    zzcflying  
    OP
       2015-06-12 12:13:40 +08:00
    @ipconfiger 我现在是按照字典存的,user_id作为key,但是如果前端做个负载均衡的话,就会有可能找不到response了。
    hellomsg
        4
    hellomsg  
       2015-06-12 12:25:12 +08:00
    @zzcflying 你意思是不是前段做负载均衡连接到不同的服务器了?如果是修改负载均衡策略行不行?
    binux
        5
    binux  
       2015-06-12 12:26:05 +08:00
    消息不要直接在进程内传输,long polling 的等待绑定到全局的一个东西,比如 redis 订阅上。每个进程负责自己的客户。消息广播到 redis 上。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1371 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 22ms · UTC 17:19 · PVG 01:19 · LAX 09:19 · JFK 12:19
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.