zoukankan      html  css  js  c++  java
  • 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 &
  • 相关阅读:
    Kubernetes基本概念之Volume
    Kubernetes对象之PersistentVolume,PersistentVolumeClaim和StorageClass
    SSDB高效能缓存系统
    python2升级python3
    pkg-config相关的常用指令
    CISSP考试经验分享
    如何在命令行添加换行符到git commit -m "xxx"
    为什么tcp-wrappers被Redhat Centos Fedora废弃?
    Docker 国内仓库和镜像
    shell脚本对代码执行时间的计时
  • 原文地址:https://www.cnblogs.com/atuotuo/p/14703753.html
Copyright © 2011-2022 走看看