Get Started with Django Channels
data:image/s3,"s3://crabby-images/6cf54/6cf54706cd2c32d021ec33cad5342418a163c658" alt=""
data:image/s3,"s3://crabby-images/3e676/3e676138464fba9f3c843f98d1799c09ed00b62e" alt=""
The web circa 2016 is significantly more powerful.
data:image/s3,"s3://crabby-images/47e2e/47e2e9efbc0f9156909ee3f511f5d7f3a5834635" alt=""
Real-Time Web
data:image/s3,"s3://crabby-images/2ccfc/2ccfcf4c5aab6b2758acd90ef5523b2c15bfaff2" alt=""
- Protocol that provides full-duplex communication
- Open connection between the client and the serve
- Send data at any time.
data:image/s3,"s3://crabby-images/f4db4/f4db4876a354daeeb2b65fbc2bfd39863c5a6f0f" alt=""
Django is built around the simple concept of requests and responses.
This doesn’t work with WebSockets!
data:image/s3,"s3://crabby-images/e7824/e7824facc7dfcec1d6427c15f74b0020b8bdf099" alt=""
Replaces the “guts” of Django — the request/response cycle — with messages that are sent across channels
Channels introduces some new concepts to Django
Channels are essentially task queues: messages get pushed onto the channel by producers, and then given to one of the consumers listening on that channel.
Django channels work across a network and allow producers and consumers to run transparently across many dynos and/or machines. This network layer is called the channel layer.
Channels is designed to use Redis as its preferred channel layer
Channels is available as a stand-alone app
Getting started: how to make a real-time chat app in Django
Simple real-time chat app
data:image/s3,"s3://crabby-images/b6c9a/b6c9a436494993ddf325c7b2f94f4b2064cb982e" alt=""
First steps — it’s still Django
The initial steps are the same as any Django app.
chat/models.py
data:image/s3,"s3://crabby-images/49da6/49da654be1c302f1f66a26d3834f005faa22a019" alt=""
First steps — it’s still Django
The initial steps are the same as any Django app.
chat/views.py
data:image/s3,"s3://crabby-images/2d3cf/2d3cfb4ad6bb67b392fe4a0aa0a1dbc4d9aa8d3a" alt=""
Where we’re going
To get a handle on what needed to be done on the backend, let’s look at the client code.
data:image/s3,"s3://crabby-images/d99d0/d99d0be4e608987459cae54d8638480d68aa6bbf" alt=""
data:image/s3,"s3://crabby-images/ef694/ef6945a287e36723e4932a92864cd5a80d5bcd14" alt=""
data:image/s3,"s3://crabby-images/d3793/d3793b291da1aab222bd7ae4d12212fbc403ac52" alt=""
Installing and setting up Channels
1. Install Channels pip install channels add "channels” to your INSTALLED_APPS
2. Choose a channel layer: pip install asgi_redis
data:image/s3,"s3://crabby-images/b0ba7/b0ba7a1a4c3139c7f89edb25ab7cc516753aca5b" alt=""
Installing and setting up Channels
3. Channel routing: Channel routing is a very similar concept to URL routing: URL routing maps URLs to view functions; channel routing maps channels to consumer functions.
4. Run with channels: Swap out Django's HTTP/WSGI-based request handler, for the one built into channels
data:image/s3,"s3://crabby-images/0bca5/0bca5b9c03225f3efe82bc205b2720cdc0203dbe" alt=""
data:image/s3,"s3://crabby-images/0208a/0208a673fea85c9cf3218dbcdca407bcd2dd9828" alt=""
data:image/s3,"s3://crabby-images/52860/528604188c2318e2d53af2fdc47b736b4f812030" alt=""
data:image/s3,"s3://crabby-images/fbfc4/fbfc46d5c825a49fec5bbaa57c7736f423acbccc" alt=""
WebSocket consumers
Channels maps WebSocket connections to three channels:
-
A message is sent to the websocket.connect channels the first time a new client (i.e. browser) connects via a WebSocket. When this happens, we’ll record that the client is now “in” a given chat room.
-
Each message the client sends on the socket gets sent across the websocket.receive channel. When a message is received, we’ll broadcast that message to all the other clients in the "room”.
-
Finally, when the client disconnects, a message is sent to websocket.disconnect. When that happens, we’ll remove the client from the “room”.
data:image/s3,"s3://crabby-images/393a6/393a6b9c7f3cd54919ce55a9cf68641b85066799" alt=""
First, we need to hook each of these channels up in routing.py:
data:image/s3,"s3://crabby-images/a53cf/a53cfc2f94a5c2f1e8f75ae72adf32c1a6ea8f58" alt=""
Let’s look at ws_connect first:
chat/consumers.py
data:image/s3,"s3://crabby-images/46ea8/46ea8c7749a37f9ff2143ccf54c85b208e6e2af3" alt=""
Now that a client is connected, let’s take a look at ws_receive. This consumer will get called each time a message is received on the WebSocket:
After that, ws_disconnect is very simple:
data:image/s3,"s3://crabby-images/3ec22/3ec22b0ca29f3e2bff832094cb20f2d38c098e6f" alt=""
data:image/s3,"s3://crabby-images/44d86/44d86702de8f32eb2d985b280ebd53631ffc29b8" alt=""
data:image/s3,"s3://crabby-images/18a65/18a656422b9c734b0ab7242f52ca0ebfb8b2d572" alt=""
data:image/s3,"s3://crabby-images/c03b3/c03b376c2c6da98c9510d40c8896d493d88b9731" alt=""
(Heroku)
Thanks!
Get Started with Django Channels
By Juan David Hernández Giraldo
Get Started with Django Channels
- 1,652