• Django


    首先推荐阅读下面博文,清晰的讲述了channels 的来龙去脉。

    https://www.cnblogs.com/skying555/p/5698115.html

    总结

    1. server & worker

    Channels将 Django分成了两部分:接口服务 (Daphne),消息消费者(worker)。所以想要处理HTTP 请求,我们得运行一个worker

    python manage.py runworker

    (顺便说一句,我们仍然可以通过运行python manage.py runserver命令来做本地测试。当这么做时, Channels只是在同一进程里运行起Daphne和一个worker。)

    2. 多实例: 服务和消费者示例

    # 多服务
    daphne xxx.asgi:channel_layer --port 8000 --bind 0.0.0.0 -v2 &
    daphne xxx.asgi:channel_layer --port 8002 --bind 0.0.0.0 -v2 &
    
    # 多消费者
    python manage.py runworker -v2 &
    python manage.py runworker -v2 &
    python manage.py runworker -v2 &
    python manage.py runworker -v2 &
    python manage.py runworker -v2 &
    python manage.py runworker -v2 &
    python manage.py runworker -v2 &
    python manage.py runworker -v2 &

    3. 关于AWSGI - Django, http请求的小结

    3.1 使用一个daphene启动Django服务后,当处理一个http 请求时,若只有一个worker在处理(未完成时)会挂起AWSGI server, 导致网站暂时无法访问或延迟访问。

    3.2 推荐给一个daphne配置多个worker,配置的方法参考机器CPU-core/processer 数量,以及实际并发的数量。

    3.3 解决 Daphne timeout:503: 给daphne添加超时设置(官方说法默认为 60s,实测大概是120s)

    daphne xxx.asgi:channel_layer -t 300 --port 8000 --bind 0.0.0.0 -v2 &
  • 相关阅读:
    python搭建开发环境
    django初探
    linux下安装Composer
    文件记录追加 file_put_content
    自定义导出表格
    异步处理接口 fsockopen
    appcache checking update
    js pix
    Event Aggregator
    ko list and css gradient
  • 原文地址:https://www.cnblogs.com/atuotuo/p/14703753.html
Copyright © 2020-2023  润新知