This is an Overly Complex Random Number Generator, created to demystify how containers work.
Demo
- User sets a Random Seed
- Clicks Generate a Random Number
- Random Number is generated
CT83 / The-Overly-Complicated-Random-Number-Generator
An Overly Complex Random Number Generator, created to demystify how containers work.
The-Overly-Complicated-Random-Number-Generator
This is an Overly Complex Random Number Generator, created to demystify how containers work.
How to Run?
Easy peasy lemon squeezy. ππ¦
-
docker-compose up --build
-
Visit
localhost
Below is an excerpt from my Blog Post about this.
Demo
- User sets a Random Seed
- Clicks Generate a Random Number
- Random Number is generated
Prerequisites
- You have an understanding of Docker and Docker Compose
- You have heard about Python, React and Redis
Aim
- To illustrate how containerization actually looks in the wild
- We will be skipping how the actual Python, JavaScript Apps work, as we want to focus on containerization here, you can find all of the code on Github - CT83/The-Complicated-Simple-Container-App
Architecture
- Nginx Proxy - Exposed on port 80, Manages networking
- React Dev Server - Accepts Input, Supports Live Reloading, Replaced with Nginx in Production
- Flask Server - Serves the API
- Redis Cache - To maintain the Task Queue
- Pythonβ¦
Prerequisites
- You have an understanding of Docker and Docker Compose
- You have heard about Python, React and Redis
Aim
- To illustrate how containerization actually looks in the wild
- We will be skipping how the actual Python, JavaScript Apps work, as we want to focus on containerization here, you can find all of the code on Github - CT83/The-Complicated-Simple-Container-App
Architecture
- Nginx Proxy - Exposed on port 80, Manages networking
- React Dev Server - Accepts Input, Supports Live Reloading, Replaced with Nginx in Production
- Flask Server - Serves the API
- Redis Cache - To maintain the Task Queue
- Python Worker - Uses specified Seed to Generate Random Number, stores it in DB
- Database - PostGreSQL DB to store generated random numbers
Working
- React App is served, user inputs the random seed.
- Seed is sent to the Flask API through a POST
- Task is added to Queue
- Worker picks up the task, generates a random number and store result in the database
- Result is returned to the user.
Configuration
Here, is the minified docker-compose-prod.yml
version: "3.3"
services:
proxy:
container_name: proxy
build:
...
ports:
- 80:80
database:
container_name: database
build: database/.
volumes:
- ./database/db_data:/var/lib/postgresql
...
client:
container_name: client
build:
...
environment:
...
api:
container_name: api
build:
...
volumes:
- ./api:/app
worker:
container_name: worker
build:
...
redis:
container_name: redis
build:
...
You can find the development docker-compose.yml here. It even supports Live Reloading for both, the Flask and React Container!
Next Steps
You could now move on to trying to push the built images to DockerHub, or add TravisCI integration!
Inspirations
Stephen Grider in his Udemy Course Docker and Kubernetes: The Complete Guide built an overly complex simple app, that greatly inspired me.
Top comments (2)
Nice one Rohan!
I wanna learn how to do that too, especially with Redis :)
Hello old friend!
Thanks you so much! β₯ π₯
It's way easier than it looks!