What is Docker?
Docker is a tool designed to make it easier to create, deploy, and run applications by using containers. Containers allow a developer to package up an application with all of the parts it needs, such as libraries and other dependencies, and deploy it as one package.
Note: This article assumes you already have Docker & Docker Compose installed and know basic Django and Python development.
Create a new file called Dockerfile
in your project root directory
This is simply a file that contains a list of instructions for docker to build our image. Basically it describes all the dependencies you need in your project in the dockerfile.
Add the following to your Dockerfile
# Step 1/10 Here we're creating our image from the python alpine image
FROM python:3.8-alpine
# Step 2/10 This is just to keep track or show that you own this image
MAINTAINER Chuckz Okoye
# Step 3/10 This helps avoid complications from running python in containers
ENV PYTHONUNBUFFERED=1
# Step 4/10 Here we copy our requirements.txt file to our docker image
COPY ./requirements.txt /requirements.txt
# Step 5/10 Here we install packages from the requirements file we just copied
RUN pip install -r /requirements.txt
# Step 6/10 Here we create a directory in our docker image
RUN mkdir /code
# Step 7/10 Here we set the created directory as our working directory in our docker image
WORKDIR /code
# Step 8/10 Here we copy the contents of our local code directory to our docker image
COPY . /code/
# Step 9/10 Here we create a user to run our application in docker
RUN adduser -D user
# Step 10/10 Here we switch the docker user to the user we created in step 9
USER user
Next we create a file called docker-compose.yml
in your project root directory
The docker-compose.yml
file is a tool for defining and running multiple services that make up our application. For example one service may be a Postgres
Database and another our Django application.
Add the following to your docker-compose.yml
file
version: "3"
services:
code:
build:
context: .
ports:
- "8000:8000"
volumes:
- .:/code
command: python manage.py runserver 0.0.0.0:8000
This file defines a single service called code
. We set the build context to .
indicating that we're running from our current directory.
In the ports
config we map our project from port
8000
on our localhost to port 8000
in our image.
The volume
config allows us to work synchronously
with the code folder in our image in real time.
The command
contains the command that is used to run our application in our docker container. age
Building and Running our Docker image
Now we can build and run our image by using the docker-compose up
command in our terminal. Also to run other django commands from the container, we can use the docker-compose run
followed by our command.
Conclusion
It takes some trial and error to get the working principle down, but once you do, development and deployment would definitely be easier. If you come across any issue setting this up, let me know in the comments section below ๐
Let's keep in touch:
Blog: chuckzokoye
Twitter: @chuckzokoye
Github: github.com/tricelex