这个想法是在工作人员上运行后台任务worker.connect
。在执行任务时,我想通过通知组将其进度发送到连接的客户端。
问题:发送到通知组的消息被延迟,直到工作人员的任务完成。因此:延迟 5 秒 ( sleep(5)
) 后,消息“开始”和“停止”同时出现在客户端上。我希望消息“开始”,然后是 5 秒延迟,然后是消息“停止”。知道为什么不是这样吗?
我正在运行以下三个进程:
daphne tests.asgi:channel_layer
python manage.py runworker --exclude-channel=worker.connect
python manage.py runworker --only-channel=worker.connect
在views.py
:
def run(request, pk):
Channel('worker.connect').send({'pk': pk})
return HttpResponse(status=200)
在consumers.py
:
def ws_connect(message):
Group('notifications').add(message.reply_channel)
message.reply_channel.send({"accept": True})
def worker_connect(message):
run_channel(message)
在views.py
:
def run_channel(message):
Group('notifications').send({'text': 'Start'})
sleep(5)
Group('notifications').send({'text': 'Stop'})
routing.py
channel_routing = {
'websocket.connect': consumers.ws_connect,
'worker.connect': consumers.worker_connect,
}