Repository for developing a real-time chatroom using Django Channels web socket and Redis. This side-project serves as a prototype/proof-of-concept for developing a real-time chatroom for mental health experts to communicate with Arduino smart watch users as part of my Final Year Project (FYP) titled 'Fitweet: Arduino-based Smart Watch for Early Anticipatory Anxiety Notification System'.
- Real-time Chatroom
- Users can go to requested room and interact live with other users in the room
- Auto scroll to bottom of chat interface every time a new message is sent/received
- WhatsApp-inspired UI for message display together with datetime
- Real-time Online User Status
- Users can see the online statuses of other users (whether they have logged in or not) in real-time
- Colour-coded for emphasis
To run this app in your local environment, run the following preferably in a virtual environment:
pip install -r requirements.txt
The app can now be viewed at localhost:8000
or preferably 127.0.0.1
.
Redis is used as a backing store for Channels. Like an in-memory cache.
If you don't have Docker installed on your computer, you need to install it before you can continue. When you have Docker running, you can run this command to start the redis server:
docker run --name <CONTAINER_NAME> -p 6379:6379 -d redis
If you don’t have Homebrew, install it with the following command:
/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install.sh)
Once Redis is installed using Homebrew, use Homebrew to launch it:
brew services start redis
To stop Redis using Homebrew:
brew services stop redis
To build a Docker image of this application and run it, do the following:
- Install Docker
- Build the image using the following:
docker build -t <NAME> .
- The t flag indicates the name for this image (an optional tag is also possible using the name:tag syntax)
- The . at the end refers that the Dockerfile is in the current directory (ensure that the image is built when in this project directory)
- Run the built image using the following:
docker run -p 8501:8501 <NAME>
- The p flag indicates publishing the exposed port to the host interface.
- 8501:8501 refers to the binding of the host port to the exposed container port.
- With this, once the container has started, the application can be viewed at
localhost:8501
.
Normally, Django uses HTTP to communicate between the client and server:
- The client sends an HTTP request to the server.
- Django parses the request, extracts a URL, and then matches it to a view.
- The view processes the request and returns an HTTP response to the client.
Unlike HTTP, the WebSockets protocol allows bi-directional communication, meaning that the server can push data to the client without being prompted by the user. With HTTP, only the client that made a request receives a response. With WebSockets, the server can communicate with multiple clients simultaneously.
The following shows the architecture of WebSockets using Django Channels:
- Django Realtime Chat App Tutorial - Simple Django Tutorial With Channels And Redis
- This extensive guide serves as the foundation for this project, where I cloned the repository provided via this GitHub link
- However, several important modifications were made, particularly in the model and front-end design.
- Deploying - Channels 3.0.3 Documentation
- The official documentation of Django Channels is used for future reference on deployment using NGINX, Redis and Daphne.
- Deploy Django + Channels + Redis + Heroku + Daphne
- This YouTube tutorial together with its GitHub repository provides a guide on how to deploy a Django-Channels-Redis-Daphne project on Heroku.
- Deploying Docker on Heroku
- This YouTube tutorial guides on how to deploy a Docker containers in Heroku, should you decide to deploy it in that manner.
- Django Channels - Updating the user’s online real-time status online
- This extensive guide serves as the foundation for the asynchronous user login status feature of this project
- However, because the guide was written back in 2019, some of the code implementations are wrong and faulty. Necessary modifications were made to successfully run the project.