Normally, those kinds of things will be much more troublesome when you want to run them in Windows compare to in Linux. However, Docker has made quite user-friendly for Windows. You just need to run the Docker installer and to enable below two things, then Docker will work like a charm.python
Create this file with the name Dockerfile
and put into your Django project root folder.mysql
# Use an official Python runtime as a parent image FROM python:2.7-slim # Set the working directory to /app WORKDIR /app # Copy the current directory contents into the container at /app ADD . /app # Install any needed packages specified in requirements.txt RUN pip install -r requirements.txt # Make port 80 available to the world outside this container EXPOSE 80 # Define environment variable ENV NAME MySite # Run manage.py when the container launches CMD ["python", "manage.py", "runserver", "0.0.0.0:80"]
You can define any required modules in requirements.txt
, and you don’t need Python or anything in requirements.txt
on your system, nor will building or running this image install them on your system.web
mysqlclient
docker build -t mysite .
docker run -p 8000:80 mysite
Create a file called docker-compose.yml in your project directory and paste the following:sql
version: '3' services: mariadb: image: mariadb environment: - MYSQL_ROOT_PASSWORD=password - MYSQL_DATABASE=docker - MYSQL_USER=user - MYSQL_PASSWORD=password web: build: . command: python manage.py runserver 0:80 volumes: - .:/app ports: - "8000:80" depends_on: - mariadb
List dangling images:docker
docker images -f dangling=true
Remove dangling images:bash
docker rmi -f $(docker images -f dangling=true -q)
Running an empty container:app
docker run -it mysite /bin/bash
Remove a container:curl
docker rm -f <container-id>
Remove all stopped containerside
docker rm $(docker ps -a -q)
You may use either docker or docker-compose to bring up your Django application, however, when in Windows and if you are using MySQL as DB, there will be an error 'No modeul named MySQLdb' and when you want to install mysqlclient or libmysqlclient-dev, there will be another error of mysql_config() not found. So in the end, I need to install the packages manually.ui
Run the image as container and then get into the container
docker run -p 8000:8000 mysite docker exec -i -t <image name> /bin/bash
Run apt-get update in order to get all the packages
apt-get update
install mysql-server for mysql_config()
apt-get install mysql-server
install libmysqlclient-dev and gcc in order to install mysqlclient for MySQLdb
apt-get install libmysqlclient-dev apt-get install gcc pip install mysqlclient
If you need to import pycurl then you need to install the prerequisite packages
apt-get install libcurl4-gnutls-dev librtmp-dev pip install pycurl
Finally, You can run the application and access it in your browser!
python manager.py runserver 0.0.0.0:8000
You could also save the changes to an image.
docker commit <container-id> <image-name>:<tag>