- [For Windows users] To install Docker Desktop, you'll need Windows 10 Pro or Enterprise version 15063.
- Install Docker
-
If you have Docker Desktop license
-
If you don't have a Docker Desktop license, you can use
colima
- Setup instructions: https://gist.github.com/jcartledge/0ce114e9719a62a4776569e80088511d
-
Important things to note:
- You will be prompted to create a DockerHub account. Follow the instructions in order to download Docker
- Follow the installation prompts (go with the default options) until you have successfully started Docker
- [Windows users] When prompted to enable Hyper-V and Containers features, click 'Ok' and let computer restart again.
- You may have to restart your computer 2-3 times.
- Start Docker on your desktop (Note: Wait for Docker to complete startup before running the subsequent commands. You'll know when startup is completed when the docker icon in your taskbar stops animating)
# start colima (if you're not using Docker Desktop)
colima start
# if you need more resources, you can specify resources like this: `colima start --cpu 8 --memory 8 --disk 100`
# build
docker build . -t my-project
# run container
docker run -it -v $(pwd):/code -p 8888:8888 my-project bash
# note: -p 8888:8888 maps port 8888 to your host machine and is needed for jupyter notebooks
# note: -v $(pwd):/code mounts your current working directory (presumably your project directory) and makes any changes instantly available in the running container
# run unit tests
nosetests
# run unit tests in watch mode and color output
nosetests --with-watch --rednose --nologcapture
If you want to run 2 long-lived commands/processes in the same container (e.g. run jupyter notebook and nosetests at the same time), you can start a second process in a running container by doing the following:
# see list of running containers
docker ps
# start a bash shell in a running container
docker exec -it <container-id> bash
# run the second command, for example, if you want to start a jupyter notebook:
jupyter notebook --ip 0.0.0.0 --no-browser --allow-root
- install dependencies on host (because your IDE can't use the dependencies inside the Docker container):
bin/install_deps_locally.sh
- tell your IDE the path to the Python virtual environment on your host
- restart your IDE (you may have to give it a minute or 2)
- start using intellisense!