从一个uwsgi调度请求到另一个运行Django Channels的uwsgi实例

问题描述 投票:0回答:1

我目前正在使用Django频道进行websocket通信。我读了这篇文章,并指出我应该将项目分成两个uwsgi实例。它说明了这一点

“Web服务器负责将正常请求分派给一个uWSGI实例,将WebSocket请求分派给另一个uWSGI实例”

现在我有两个uwsgi实例正在运行。这就是我如何运行两者。

这个uwsgi处理正常的django站点请求

uwsgi --virtualenv /home/ec2-user/MyProjVenv --socket /home/ec2-user/MyProjVenv/MyProjWeb/site1.socket --chmod-socket=777 --buffer-size=32768 --workers=5 --master --module main.wsgi

这个uwsgi处理websocket请求

uwsgi --virtualenv /home/ec2-user/MyProjVenv --http-socket /home/ec2-user/MyProjVenv/MyProjWeb/web.socket --gevent 1000 --http-websockets --workers=2 --master --chmod-socket=777  --module main.wsgi_websocket

现在websocket uwsgi启动main.wsgi_websocket

main.wsgi_websocket的代码就是这个

import os
import gevent.socket
import redis.connection
redis.connection.socket = gevent.socket
os.environ.update(DJANGO_SETTINGS_MODULE='main.settings')
from ws4redis.uwsgi_runserver import uWSGIWebsocketServer
application = uWSGIWebsocketServer()

现在,在启动了两个uwsgi实例之后,我能够访问网站了.webocket uwsgi实例也接收数据但是我不确定它是否将数据传递到django网站uwsgi实例,它基本上使用django频道并具有处理程序发送/接收功能。我在这里使用Django频道,这是我在Django频道的设置中指定的配置

CHANNEL_LAYERS = {
    "default": {
        "BACKEND": "asgi_redis.RedisChannelLayer",
        "CONFIG": {
            "hosts": [(redis_host, 6379)],
        },
       "ROUTING": "main.routing.channel_routing", 
    },
}

信道路由就是这样

channel_routing = [
    include("chat.routing.websocket_routing", path=r"^/chat/stream"),
    include("chat.routing.custom_routing"),
]

这就是我所拥有的websocket_routing

websocket_routing = [
    route("websocket.connect", ws_connect),


    # Called when WebSockets get sent a data frame
    route("websocket.receive", ws_receive),


    # Called when WebSockets disconnect
    route("websocket.disconnect", ws_disconnect),
]

现在的问题是我的ws_receive从未被调用过。如果我使用ipaddress:8000/chat/stream在我的本地开发机器上进行测试,这种方法非常好但是我不知道为什么当我使用ipadress/ws/时我的接收没有被调用。我确信我的其他uwsgi实例正在获取该数据,但我不知道如何将其传递给djnago方面的另一个uwsgi实例,如果是,那么为什么我的接收没有被调用?对此的任何建议肯定会有所帮助

django websocket redis uwsgi django-channels
1个回答
0
投票

当我在这里看到你的另一个问题Nginx with Daphne gives 502 Bad Gateway时,我想知道这件事

拆分项目是个好主意。我假设这两个实例在nginx后面运行(来自你的上述问题)。

那么,nginx应该决定哪个请求进入哪个实例?你可以使用不同的url路径为每个channelsdjango应用程序。

例:

对于django app:/whatever/whatever/...channels/ws/whatever/...

假设你的channels消费者实例是8000。

将此添加到您的nginx

location /ws/ {
            proxy_pass http://0.0.0.0:8000;
            proxy_http_version 1.1;
            proxy_set_header Upgrade $http_upgrade;
            proxy_set_header Connection "upgrade";

            proxy_redirect     off;
            proxy_set_header   Host $host;
            proxy_set_header   X-Real-IP $remote_addr;
            proxy_set_header   X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_set_header   X-Forwarded-Host $server_name;
        }

这样,无论您的查询是什么,如果url以/ws/开头,它都会被在端口8000上运行的任何实例使用。

© www.soinside.com 2019 - 2024. All rights reserved.