我正在 Openshift 云上部署一个 Django 项目。该项目使用通道和 Websockets 使其异步工作。问题是我无法成功地将浏览器中的 websockets 连接到我在服务器端运行的 Daphne 服务器。
我正在使用 django (python2.7) 和redis墨盒使其运行。
我使用的 post_deploy 脚本如下所示:
...
python manage.py runworker -v2 && daphne myapp.asgi:channel_layer -p 8443 -b $OPENSHIFT_REDIS_HOST -v2
...
这是我的 Django 配置。在settings.py 中:
...
ALLOWED_HOSTS = [
socket.gethostname(),
os.environ.get('OPENSHIFT_APP_DNS'),
]
CHANNEL_LAYERS = {
"default": {
"BACKEND": "asgi_redis.RedisChannelLayer",
"CONFIG": {
"hosts": [("redis://:{}@{}:{}/0").format(
OPENSHIFT_REDIS_PASSWORD,
OPENSHIFT_REDIS_HOST,
OPENSHIFT_REDIS_PORT
)],
},
"ROUTING": "myapp.routing.channel_routing",
},
}
...
在routing.py 中:
...
ws_routing = [
routing.route("websocket.connect", ws_connect),
routing.route("websocket.receive", ws_receive),
routing.route("websocket.disconnect", ws_disconnect),
]
channel_routing = [
include(ws_routing, path=r"^/sync"),
]
...
在消费者.py中;
def ws_connect(message):
Group("notifications").add(message.reply_channel)
def ws_disconnect(message):
Group("notifications").discard(message.reply_channel)
def ws_receive(message):
print "Receiving: '%s' from %s" % (message.content['text'], message.content['reply_channel'])
在客户端,我正在运行以下代码:
var ws_scheme = window.location.protocol == "https:" ? "wss" : "ws";
var path = ws_scheme+'://'+window.location.host + ':8443/sync';
var ws = new WebSocket(path);
ws.onmessage = function(message) {
console.log(message.data);
}
ws.onopen = function() {
this.send('WS Connecting to receive updates!');
}
请注意,由于此文档,我在 Daphne 设置和 WebSockets 设置中使用了端口 8443 。此外,Daphne 绑定到 OPENSHIFT_HOST 地址,因为在 Openshift 中无法将其绑定到 0.0.0.0(权限问题)
输出如下所示:
在客户端一切看起来都不错,但如果你还记得的话,在consumer.py中我有这个:
def ws_receive(message):
print "Receiving: '%s' from %s" % (message.content['text'], message.content['reply_channel'])
因此,在我的终端中,服务器应该打印出类似:“接收:来自”的内容,但事实并非如此。我在这里缺少什么?
tl; dr:客户端 websocket 看起来连接正确,但服务器没有打印出消息来确认它。