- What is Docker?
- Installing Docker on Mac OS X
- Installing Docker on Windows
- Installing Docker on Linux
- Running the Oncoscape Docker container
- Developing Oncoscape inside a Docker container
##1. What is Docker?
Docker is an open platform for building, shipping and running applications. It allows development teams to produce self-contained application containers that include not only the application but an environment, configuration and all required dependencies. If a Docker container based application runs on your development workstation, it will run exactly the same on any Docker powered systems without modification and without worrying about any application specific dependencies.
Development teams using Docker can simply provide the container to operations teams to deploy, or to users of the application and be assured that the application will run.
Docker is not just for ease of deployment, it's also provides developers with a clean, isolated environment to consistently code, build and test their application on their development workstation.
##2. Installing Docker on Mac OS X
Running a Docker environment on Mac OS X requires Mac OS X 10.8 "Mountain Lion" or higher.
To get docker running on a Mac follow the instructions below:
- Go to the Docker Toolbox Mac OS page: https://www.docker.com/docker-toolbox
- Download the Mac OS X version of the installer
- Double-click on the downloaded installer (DockerToolbox-1.x.pkg)
- Following the install wizard to install the Docker-Toolbox
- See http://docs.docker.com/mac/step_one/ for more detailed install instructions
After the Docker Toolbox as been successfully installed, open a terminal and issue the following command:
docker-machine ls
The output of the above command should look like this:
NAME ACTIVE DRIVER STATE URL SWARM
default virtualbox Stopped
This show you the name and state of the default Docker VM. You'll need to start up this VM before proceeding as follows:
docker-machine start default
After the above command returns the Docker VM should be up and running. To configure your docker client to communicate with this new environment issue the following command in a terminal shell:
eval "$(docker-machine env default)"
Now let's make sure it's working by running a small "hello world" container with the following command:
docker run --rm hello-world
If everything works as expected you should, the output of the above command should like something like this:
$ docker run --rm hello-world
Unable to find image 'hello-world:latest' locally
latest: Pulling from library/hello-world
b901d36b6f2f: Pull complete
0a6ba66e537a: Pull complete
Digest: sha256:517f03be3f8169d84711c9ffb2b3235a4d27c1eb4ad147f6248c8040adb93113
Status: Downloaded newer image for hello-world:latest
Hello from Docker.
This message shows that your installation appears to be working correctly.
If your output looks like the above, then you're Mac is ready to use Docker.
##3. Installing Docker on Windows
Running a Docker environment on Microsoft Windows requires Windows 7, 8.x, or 10
To get docker running on on Windows, follow the instructions below:
- Go to the Docker Toolbox page: https://www.docker.com/docker-toolbox
- Download the Microsoft Windows version of the installer
- Double-click on the downloaded installer (DockerToolbox-1.x.exe)
- Following the install wizard to install the Docker-Toolbox
- See http://docs.docker.com/windows/step_one/ for more detailed install instructions
After the Docker Toolbox has been successfully installed, double click on the "Docker Quickstart Terminal" shortcut that was created during the installation process. This will open a new terminal Window and start the default Docker VM (this may take a minute or two, especially the first time). When it's finished starting the terminal will look like the following:
## .
## ## ## ==
## ## ## ## ## ===
/"""""""""""""""""\___/ ===
~~~ {~~ ~~~~ ~~~ ~~~~ ~~~ ~ / ===- ~~~
\______ o __/
\ \ __/
\____\_______/
docker is configured to use the default machine with IP 192.168.99.100
For help getting started, check out the docs at https://docs.docker.com
NOTE: When using interactive commands, prepend winpty. Examples: 'winpty docker run -it ...', 'winpty docker exec -it ...'.
MINGW64 ~
Now lets make sure it's working by running a small "hello world" container with the following command:
docker run --rm hello-world
If everything works as expected you should, the output of the above command should like something like this:
$ docker run --rm hello-world
Unable to find image 'hello-world:latest' locally
latest: Pulling from library/hello-world
b901d36b6f2f: Pull complete
0a6ba66e537a: Pull complete
Digest: sha256:517f03be3f8169d84711c9ffb2b3235a4d27c1eb4ad147f6248c8040adb93113
Status: Downloaded newer image for hello-world:latest
Hello from Docker.
This message shows that your installation appears to be working correctly.
If you're output looks like the above, then your Windows system is ready to use Docker
I you get an error like "An error occurred trying to connect..." you probably need update the docker environment variables in the Docker terminal with the command below and try again:
eval "$(docker-machine env --shell=bash default)"
##4. Installing Docker on Linux
Docker runs natively on Linux so you won't have to install an enabling technology like Docker Machine or Boot2Docker as is required on Windows and Mac OS platforms.
Docker requires a 64-bit version regardless and your kernel must be 3.10 at minimum. Linux distributions such as Ubuntu 14.04+ and CentOS 7 are ready to run docker. To pull images from the the Docker Hub you'll need docker version 1.6 or higher.
Docker can be installed using your distributions package manager. For example the following will install Docker 1.6 on Ubuntu 14.04:
sudo apt-get -y update
sudo apt-get -y install docker.io
As an alternative to using our distributions packages (above method), you can install the very latest version of Docker by getting Docker packages directly from the Docker project. For example, the commands below will get the very latest version of Docker running on an Ubuntu 14.04 system:
sudo apt-key adv --keyserver hkp://pgp.mit.edu:80 --recv-keys 58118E89F3A912897C070ADBF76221572C52609D
sudo echo "deb https://apt.dockerproject.org/repo ubuntu-trusty main" > /etc/apt/sources.list.d/docker.list
sudo apt-get -y update
sudo apt-get -y purge lxc-docker*
sudo apt-cache -y policy docker-engine
sudo apt-get -y install docker-engine
After you've installed Docker on your Linux system following one of the above methods, make sure it's working by running a small "hello world" container with the following command:
sudo docker run --rm hello-world
If everything works as expected the output of the above command should look something like this:
$ sudo docker run hello-world
Unable to find image 'hello-world' locally
Pulling repository hello-world
975b84d108f1: Download complete
3f12c794407e: Download complete
Hello from Docker.
This message shows that your installation appears to be working correctly.
NOTE: to avoid having to use "sudo" for every docker command, you and add your account to the local "docker" group (create it if it doesn't already exist).
##5. Running the Oncoscape Docker container
This section covers running Oncoscape in a container for either test/demo purposes or deploying on a production server. If you just want to get Oncoscape up and running quickly to check it out, then this section is for you. If you want to build and develop Oncoscape in a container, skip this section and move on to Developing Oncoscape inside a Docker container.
Before you can run Oncoscape, we first need to pull it down to the system we are going to run it on. This is accomplished with the following command:
docker pull fredhutch/oncoscape:develop
The above command will take a while as it downloads all the layers of the Oncoscape image. When it's done, you can run the "develop" branch version of Oncoscape with the following command:
docker run -d --name oncoscapedev -p 80:80 fredhutch/oncoscape:develop
The above command will create a new container running the development version of Oncoscape. It will name the container "oncoscapedev" and will bind tcp port 80 inside the container to tcp port 80 on the Docker system.
If you'd rather run the stable version (master branch) of Oncoscape
docker pull oncoscape
docker run -d --name oncoscapemaster -p 80:7777 fredhutch/oncoscape:latest
To access the application just open a web browser (Chrome is currently the only supported browser) and navigate to the application depending on how you are running Docker:
- Local Linux workstation: http://localhost
- Remote Linux server: http://removeservername
- Local Mac OS X or Windows system: you'll first need to determine the IP address of the Docker Machine with the command "docker-machine ip default", then point your browser to this IP address for example http://192.168.99.100 (replace 192.168.99.100 with the IP of your Docker Machine VM).
You can see which containers are running on your system with the "docker ps" command:
$ docker ps
CONTAINER ID IMAGE STATUS PORTS NAMES
6cfad3997f0d fredhutch/oncoscape:develop Up 3 hours 0.0.0.0:80->80/tcp oncoscapedev
You can stop/start containers that you've created with the 'docker stop/start containername' commands as follows:
$ docker stop oncoscapedev
oncoscapedev
$ docker start oncoscapedev
oncoscapedev
If you want to delete a container, first stop it then delete with the 'docker rm containername' command as follows:
$ docker stop oncoscapedev
oncoscapedev
$ docker rm oncoscapedev
oncoscapedev
##6. Developing Oncoscape inside a Docker container
In the previous section we simply ran Oncoscape in a container, but Docker is not just for running and deploying applications, it’s great for development too. Using Docker for development provides consistent, clean development environment. Each build can be in a fresh environment without any dependencies on your development workstation or clashes/contamination with your workstation. All developers can use the same OS, same system libraries, same language runtime, no matter what host OS they are using (even Windows). The development environment is the exact same as the production environment. You only need Docker to develop; you don’t need to install a bunch of language environments, libraries and tools on your machine.
A Docker container recipe for the Oncoscape development environment is located at https://github.com/FredHutch/Oncoscape-dev-environment
To use the Oncoscape development container use 'git' to clone the Oncoscape development container repository to your Docker enabled development system, build a container image and then run it. Here are the commands required to create a container image tagged "oncodev" (you can name it something else if you would like):
git clone https://github.com/FredHutch/Oncoscape-dev-environment.git
cd Oncoscape-dev-environment
docker build -t oncodev .
The build process will take several minutes to complete. When the build is finished, there will be a new container image registered with your Docker engine named "oncodev" (or whatever you named it). Check to see that the new image was registered with the following command:
docker images
The above command will list the images registered with your docker engine and will look similar to the following:
REPOSITORY TAG IMAGE ID CREATED VIRTUAL SIZE
oncodev latest 31ee6c745277 2 minutes ago 751.8 MB
Now that we have an image registered, you are ready to start making development environment containers. To use the development environment, create and run a container from the image you built and registered. Here is an example (assuming you named your image 'oncodev'):
docker run -ti -p 80:80 --name myoncodev01 --hostname myoncodev01 oncodev
Paramater Description:
- '--name myoncodev01' flag tags this container (choose whatever name you like).
- '--hostname myoncodev01' sets the hostname inside the container to match the container instance name. The bash prompt inside the container will include the provided hostname to make it clear what environment you are currently in.
- '-p 80:80' flag tells docker that you want to bind TCP port 80 inside your container to TCP port 80 on your Docker-Machine VM (or directly to the host on Linux).
After you execute the above command you'll be dropped to a bash shell inside this new container. You are now root in an isolated Linux environment that has everything that you need to build and run Oncoscape. The container is empty so you'll need to clone the Oncoscape repo (git is included in the container) and install/build/configure/run as you like. You can create new branches, edit code (vim, emacs and nano are provided), commit and push to github right from inside the container.
NOTE: Windows users only. While the "Docker Quick Start Terminal" is fine for managing, starting, and stopping containers, you'll want to use either the standard command prompt (cmd.exe) or Powershell consoles for interactive work such editing files inside the container. Note that when using 'vi' in a container via cmd.exe or Powershell consoles, the arrow keys do not work and you'll need to use the traditional 'hjkl' keys to move the cursor: 'h'=left, 'j'=down, 'k'=up, 'l'=right.
Setup the environment variables required by docker for the shell of your choice as shown below:
Classic command prompt (cmd.exe)
FOR /f "tokens=*" %i IN ('docker-machine.exe env --shell=cmd default') DO %i
Powershell
docker-machine.exe env --shell=powershell default | Invoke-Expression
After you build and run Oncoscape in a container you'll likely want to point your browser at it. If you are running docker on Linux, you simply point your browser at either http://localhost or http://servername if it's running on a remote server. If you are running Docker on Mac OS X or Windows you first have to determine the IP address of the Docker Machine VM. To do so you'll need to run the following command:
docker-machine ip default
The output of the above command will be a private IP address that you can only reach from your development workstation. After you have this IP address simply point you browser at it with the desired port; "http://192.168.99.100" for example.
To stop your development container, simply exit the bash shell with the "exit" command. This will stop the container and drop you back on your workstation’s command line. You can see all of your containers running and stopped with the following command:
docker ps -a
The output of the above command will look similar to the following:
CONTAINER ID IMAGE COMMAND CREATED STATUS NAMES
3bb2bc400dd3 oncodev "bash" 19 minutes ago Exited 7 seconds ago myoncodev01
If you want to start your container again and enter it, simply run the following commands replacing "myoncodev01" with the name of your container:
docker start myoncodev01
docker attach myoncodev01
This will drop you back into an instance of bash running inside your container.
You're not limited to a single container, you can have as many different Oncoscape development environments on your system as you need.
In the examples above we cloned the Oncocape repository inside of the container. If you'd rather clone it to your workstation directly and access it from inside your container you can use the Docker 'volumes' feature. For example let's say you have cloned the Oncoscape repo to /Users/myuser/Oncoscape and want to fire up a container and access this external data from inside your container. To accomplish this you'll need to use the '-v' flag when creating a new container and tell it what folder on your workstation you want to be mounted inside the container. Here is an example:
docker run -ti -p 80:80 -v /Users/myuser/Oncoscape:/opt/Oncoscape --name myoncodev02 --hostname myoncodev02 oncodev
After running the above command, you should see that the '/User/myuser/Oncoscape' folder on your development workstation is now mounted read/write to '/opt/Oncoscape' inside this new container. You can change to this directory and use git just like you do on your workstation. It's worth noting that any modifications to this directory or files it contains inside the container, is directly modifying the files outside of your container. This approach can save you a lot of time and disk space by not having to clone the repo inside each container, but if you need true isolation between each conatiner, this might not be the right approach.
NOTE: Windows users can't specify the local folder they want mounted in the traditional 'C:/xyz' format. You'll need to use the '/c/xzy' format. For example "-v /c/Users/myuser/Oncoscape:/opt/Oncoscape" will mount 'C:\Users\myuser\Oncoscape' on your workstation to '/opt/Oncoscape' inside the container.
To delete a container you don't need any longer, it must first be stopped if it's currently running then use the following command replacing "myoncodev03" with the name of the container you wish to delete:
docker rm myoncodev03
To delete the oncodev image that you built, first there must be no containers running or stopped that are based off of it. When there are no containers created from the oncodev image remaining you can delete this image with the following command replacing "oncodev" with name of the image you created:
docker rmi oncodev
You can see which containers are on you workstation with the "docker ps -a" command and which images are on your workstation with the "docker images" command.