Being new to the container space, it is a bit hard to grok all the different parts, how they worked together and how the space has evolved.
Containers
Docker / Rocket
cgroups
mount
LXC - Linux container
OpenVZ
Virtual Machine
Home
This will attempt to be an overview of what I learned at Containers Days Boston, a 2 day event where I listened to a bunch of knowledgeable speakers onsite, and in the bars, as well as attended a Docker workshop on day 2. I have been container curious for a while, and although I have worked with Virtual Machines and found vagrant to be invaluable when setting up environments or deploying to different environments, containers were more of a buzz word that I hoped to play with some day. I am all too familiar with logging on to a machine to find out that something has been set manually, or having to recreate a machine, but having no obvious way to do that apart from some outdated docs or using the `history` command. Containers to the rescue? I'm hoping so!
Jeff and Kir started out with the motivation and history behind all this virtualization: time sharing of expensive mainframe computers at universities. Jeff gave the Unix side of the story, and Kir gave the Linux (OpenVZ) side of the story.
Virtual Machine (or guests) sit on top of a Hypervisor which can be either software or hardware that runs the VM.
Two types of hypervisors: Type-1: native or bare-metal hypervisors Type-2: hosted hypervisors VM must emulate the underlying hardware i.e. boot up drivers, have their own file system (not shared with host), etc. Virtual Machine (VMs) are slow to start up because they must set up an entire emulator for a machine. VMs were good ways for sandboxing. If one VM goes down, the other VMS remain running.
Fun fact: JVM was the first Virtual Machine that didn't emulate underlying hardware.
Containers in Linux / Unix are enabled by the ability to group processes together and add resource controls to that group. Resource limits (IO, CPU) can be set on a containers and apply to the entire group of processes that make up the container. Each container has its own group of processes, own isolated diskspace or namespace, own virtual network device (each container has its own IP address), own users / root, and mounting capabilities, i.e. shared drives can be mounted to the the group of processes.
In 2007 engineers at google started working on cgroups
as a way to isolate and group a set of processes and set limits for all processes in a group. cgroups
were accepted into the Linux kernel since 2.6.24 (2008). Before cgroups were accepted in the kernel only ulimit
was available which could set resource limits fro ONE process, but this is not sufficient as applications require more than one process.
Since containers all run on top of the same Kernel, one must run "guests" or "Virtualized OS" that run on the the same kernel version.
cgroups + namespaces for resource controls (I/O, RAM, CPU)
LXC (Linux Containers) - OS level virtualization for running multiple isolated Linux systems (containers) [wiki]
OpenVZ containers using cgroup
+ namespaces (openVZ team implemented namespace)
Solaris Containers (including Solaris Zones)
Containers are still pretty low level, so docker is a nice API that will create and mange your containers for you. As far as I understand, Docker can be used with different container backends, i.e. OpenVZ, or Solaris Zones. Boyd gave a nice docker tutorial on day 2 docker 101
Docker gives you commands for running / managing containers:
docker start
docker stop
The DockerFile is where you declare what you want your container to run, which volumes you want mounted, and make it all explicit and versionable.
FROM odise/busybox-python
WORKDIR /code
RUN easy_install redis && easy_install flask
ADD . /code # mounts the current dir '.' to the '/code' path inside the container (shared dir with the host)
CMD python app.py
There are other container runtime APIs apart from Docker, i.e. CoreOS Rocket
Once you have your container image you can push it to a shared repository where other developers can gain access to it. For example the docker API has commands to tag your container and push it to share repository.
$ docker tag mysmallapp:latest quay.io/{quayusername}/myquayapp:1.0
$ docker push quay.io/{quayusername/myquayapp:1.0