Introduction to Docker
data:image/s3,"s3://crabby-images/715d0/715d0758e10b8619f4cdb08b70a11acde6e1c4ac" alt=""
Andrew T. Baker
data:image/s3,"s3://crabby-images/85117/85117e3a1723d70d5e7dcd4ae2f5140afb564fb1" alt=""
Today
-
What is Docker?
-
Docker vocabulary
-
Docker's past, present, and future
-
Your future in the cloud
-
Questions
Virtualization tool?
data:image/s3,"s3://crabby-images/8a487/8a48745a40cd230c760388ef97c6ebd1a3dd8d51" alt=""
data:image/s3,"s3://crabby-images/53052/530525209bc397d851fff77405530f1d6807603e" alt=""
Configuration manager?
data:image/s3,"s3://crabby-images/38c6a/38c6a05dd5db937646254d0b64b599d397fda28f" alt=""
data:image/s3,"s3://crabby-images/ced94/ced94e504e774d6e97d3d9e79cca2c1d830bcfc4" alt=""
VM manager?
data:image/s3,"s3://crabby-images/b9519/b9519057b38a4eaa3050d83a48464257799de073" alt=""
cgroups?
LXC?
libvirt?
go?
Docker.com says
Docker is an open platform for developers and sysadmins to build, ship, and run distributed applications.
Docker Engine
A portable, lightweight runtime and packaging tool
Docker Hub
A cloud service for sharing applications and automating workflows
data:image/s3,"s3://crabby-images/33e69/33e69759dd0e6d9fdde0eb892d8459d27601851c" alt=""
Less portable, minimal overhead
Most portable,
lots of overhead
Manual
configuration
Traditional VMs
CM tools
Docker
data:image/s3,"s3://crabby-images/611e2/611e2302199edc9aff7342f32f891ea625f3b479" alt=""
data:image/s3,"s3://crabby-images/2cadb/2cadb84a38a00644b84d750b9555f6c370896a12" alt=""
data:image/s3,"s3://crabby-images/ce1b9/ce1b9f67455d46ce16703566e54b34eabca17fb3" alt=""
Containers
Your applications run in containers
$ docker run busybox /bin/echo "hello world"
hello world
docker run [OPTIONS] IMAGE [COMMAND] [ARG...]
Images
Saved states of containers.
$ docker history atbaker/sd-django
IMAGE CREATED CREATED BY SIZE
2c69173d3c3e 6 months ago /bin/sh -c apt-get clean && rm -rf /var/lib/a 7 B
cf07ee82aaa6 6 months ago /bin/sh -c chown root /opt/sd_client.py /var/ 1.162 kB
4a3046bdcd25 6 months ago /bin/sh -c #(nop) ADD file:0854b61af5a8f7051c 259 B
519ac326d2de 6 months ago /bin/sh -c #(nop) ADD file:03065d55ff7e64caa9 896 B
5f87ccb7c84f 6 months ago /bin/sh -c chown root /etc/service/gunicorn/r 871 B
aa069b102781 6 months ago /bin/sh -c #(nop) ADD file:4683e735d1f7a57fd5 864 B
da64e86860ea 6 months ago /bin/sh -c mkdir /etc/service/gunicorn 7 B
9109839d1887 6 months ago /bin/sh -c touch /var/log/gunicorn/error.log 7 B
5e628a947f45 6 months ago /bin/sh -c touch /var/log/gunicorn/access.log 7 B
57b25445ef0b 6 months ago /bin/sh -c mkdir /var/log/gunicorn 7 B
dc008bbf46e8 6 months ago /bin/sh -c /var/www/venv/bin/django-admin.py 747.5 kB
d75444a0b891 6 months ago /bin/sh -c /var/www/venv/bin/django-admin.py 45.49 kB
4b6f8f5021aa 6 months ago /bin/sh -c #(nop) ENV SECRET_KEY=no-so-secret 0 B
93a3749a8817 6 months ago /bin/sh -c #(nop) ENV DJANGO_SETTINGS_MODULE= 0 B
3d67fca00fe8 6 months ago /bin/sh -c #(nop) ENV PYTHONPATH=$PYTHONPATH: 0 B
1b2851b048f7 6 months ago /bin/sh -c /var/www/venv/bin/pip install -r / 30.19 MB
7c9a3b2daefb 6 months ago /bin/sh -c virtualenv /var/www/venv 11.62 MB
6b468cc8cefe 6 months ago /bin/sh -c pip install virtualenv 1.921 MB
Dockerfiles (builder)
Series of commands to build an image
# Spin-docker example dockerfile for a Django project
# Use phusion/baseimage as base image
FROM phusion/baseimage:0.9.8
MAINTAINER Andrew T. Baker <andrew@andrewtorkbaker.com>
# Add the Django app and install its requirements
ADD sd_sample_project /var/www/django
RUN apt-get install -y python-pip
RUN pip install virtualenv
RUN virtualenv /var/www/venv
RUN /.../venv/bin/pip install -r /.../requirements.txt
...
Docker
Repository
Git
Repository
collection of commits
Container
Checkout
used for local execution
Docker Hub
GitHub
popular remote server
Image
Commit
saved state
An open-source
success story
- dotCloud side project revealed at PyCon 2013
- Since then:
- 100 million Docker Engine downloads
- 45,000 "Dockerized" applications in Docker Hub
- 720+ community contributors
- 18,000+ GitHub stars
- dotCloud changes its name to Docker
1.0 released in June 2014
data:image/s3,"s3://crabby-images/a488b/a488bb03e3b8d1f61bcfd1e0b0f200c50642c62a" alt=""
Source: Docker tweet
data:image/s3,"s3://crabby-images/80e7a/80e7a92148e410b35532b1f398803f2300739129" alt=""
Source: Docker blog
What are people doing with Docker?
Development environments
data:image/s3,"s3://crabby-images/a801d/a801d7224e4fdd902f8f8c15a10f5691c997872d" alt=""
Platform-as-a-Service (PaaS)
data:image/s3,"s3://crabby-images/5f8e9/5f8e930647ed020e87df47528d0c074aabea27e1" alt=""
data:image/s3,"s3://crabby-images/e0d23/e0d237d750dd27d0077a1a19d9b06004fec75b20" alt=""
data:image/s3,"s3://crabby-images/d9a87/d9a8799234987835d578a72c1dc0145dd53ce68d" alt=""
Continuous Integration (CI)
data:image/s3,"s3://crabby-images/d6a3b/d6a3be53a9d380b4b9e22c6e188c03e660897af0" alt=""
Educational sandboxes
data:image/s3,"s3://crabby-images/57d68/57d685047be5c21d040a39fee8b06615998d7b18" alt=""
And the tools are getting better too
boot2docker
data:image/s3,"s3://crabby-images/cb038/cb0382ccebe9d4748c40963e5b3fe567777cd1c3" alt=""
Docker library images
data:image/s3,"s3://crabby-images/674ee/674ee070ed318502faf2833b9addc44270bcb6d3" alt=""
GUIs
data:image/s3,"s3://crabby-images/2dbaa/2dbaaa54ee07565506c9c21bb1fa51a568f50598" alt=""
Cloud-agnostic hosting
data:image/s3,"s3://crabby-images/210bc/210bc54083623da5c8583a5f417a7319c4ef5a45" alt=""
Container-specific hosting
data:image/s3,"s3://crabby-images/6078a/6078a4bd5766cc43c4cec7c081d3def1457b1ff9" alt=""
Container-specific hosting
data:image/s3,"s3://crabby-images/dab07/dab07feeb8521f3eb20ca5ee7de8adbfb3eec492" alt=""
Container-specific hosting
data:image/s3,"s3://crabby-images/ec399/ec399691cb24cc7609ccc2dfd94438c2213060f2" alt=""
What's next
for Docker?
2014
- Get to 1.0 (production-ready)
- Establish partnerships
- Round out some rough edges (v1.3)
2015
- Make Docker easier to use
- Popularize best practices for scaling
- "Include more batteries" (w/o cannibalizing ecosystem)
- Address security concerns
Containers,
the cloud, and you
A new player
data:image/s3,"s3://crabby-images/e3543/e3543438e1c71a696a9b810b86b23aa33de599bf" alt=""
Cloud computing average monthly cost
data:image/s3,"s3://crabby-images/3ab16/3ab16069bbcd09cbed8b45d24692b84e107a43eb" alt=""
Source: RBC Capital / Business Insider
Switching clouds
in minutes for...
- Service outages
- CPU/Network/IO performance
- Special pricing tailored just for you
Containers give you the flexibility to do it
Questions
[Backup slides]
About you
Introduction to Docker (Codementor.io)
By Andrew T. Baker
Introduction to Docker (Codementor.io)
Deck used in my "Introduction to Docker" Codementor.io Office Hours.
- 35,911