4

这个想法是在工作人员上运行后台任务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,
}
4

1 回答 1

6

您可以将immediately=True作为参数添加到send函数中。根据消息来源:

发送被延迟到消费者完成。要覆盖它,您可以立即传递=True。

https://github.com/django/channels/blob/master/channels/channel.py#L32

于 2017-01-16T20:56:57.593 回答