Channels является расширением для Django, которое позволяет добавить функциональность асинхронных задач и обработки веб-сокетов. Изначально Django был создан для обработки синхронных запросов от клиентов.
Однако с появлением веб-сокетов и их возможностью устанавливать постоянное соединение между клиентом и сервером, возникла необходимость в асинхронной обработке этих соединений. Раньше каждое новое сообщение от клиента обрабатывалось на сервере только после того, как предыдущее сообщение от клиента было полностью обработано, и ответ был отправлен. Это называется моделью запрос-ответ. В случае с веб-сокетами, когда соединение устанавливается и остается открытым, такая модель становится неэффективной.
Channels позволяет создавать асинхронные обработчики для веб-сокетов, чтобы сервер мог транслировать сообщения клиентам по мере их поступления, без необходимости дожидаться полной обработки предыдущих сообщений.
Однако Channels все же использует цикл обработки запросов Django для работы с веб-сокетами. Это означает, что все сообщения в сокет будут отправлены только после того, как все предыдущие запросы были обработаны. Это связано с ограничениями Django и его моделью обработки запросов-ответов. На самом деле, Channels предоставляет асинхронное API для обработки сообщений внутри обработчиков, но фактическая отправка сообщений в сокет выполняется синхронно, до окончания обработки предыдущих запросов.
Однако, это не означает, что вам придется ждать полной обработки всех запросов, чтобы отправить сообщение клиенту. Channels предоставляет возможность асинхронной обработки запросов в рамках обработчиков веб-сокетов, что позволяет вам использовать асинхронные вызовы, выполнять длительные операции или параллельно обрабатывать несколько запросов. Таким образом, вы можете использовать преимущества асинхронности, даже если фактическое отправление сообщений происходит синхронно.
Итак, причина, по которой Channels посылает все сообщения в сокет только после обработки запроса, связана с архитектурной особенностью Django и его модели обработки запросов-ответов. Однако использование Channels позволяет создавать асинхронные обработчики для веб-сокетов и выполнение дополнительных операций внутри обработчиков.