docker/contrib/docker-build
Solomon Hykes 24ddfe3f25 Documented who decides what and how. 2013-05-28 19:39:09 -07:00
..
MAINTAINERS Documented who decides what and how. 2013-05-28 19:39:09 -07:00
README Added docker-build (formerly github.com/shykes/changer) as a contrib script 2013-04-11 14:44:39 -07:00
docker-build closes #522 2013-05-04 21:20:41 -07:00
example.changefile Fix example dockerfile 2013-05-01 00:44:36 -07:00
myscript Added dummy script for docker-build example 2013-05-01 00:49:28 -07:00

README

# docker-build: build your software with docker

## Description

docker-build is a script to build docker images from source. It will be deprecated once the 'build' feature is incorporated into docker itself (See https://github.com/dotcloud/docker/issues/278)

Author: Solomon Hykes <solomon@dotcloud.com>


## Install

docker-builder requires:

1) A reasonably recent Python setup (tested on 2.7.2).

2) A running docker daemon at version 0.1.4 or more recent (http://www.docker.io/gettingstarted)


## Usage

First create a valid Changefile, which defines a sequence of changes to apply to a base image.

    $ cat Changefile
    # Start build from a know base image
    from	base:ubuntu-12.10
    # Update ubuntu sources
    run	echo 'deb http://archive.ubuntu.com/ubuntu quantal main universe multiverse' > /etc/apt/sources.list
    run	apt-get update
    # Install system packages
    run	DEBIAN_FRONTEND=noninteractive apt-get install -y -q git
    run DEBIAN_FRONTEND=noninteractive apt-get install -y -q curl
    run DEBIAN_FRONTEND=noninteractive apt-get install -y -q golang
    # Insert files from the host (./myscript must be present in the current directory)
    copy	myscript /usr/local/bin/myscript


Run docker-build, and pass the contents of your Changefile as standard input.

    $ IMG=$(./docker-build < Changefile)

This will take a while: for each line of the changefile, docker-build will:

1. Create a new container to execute the given command or insert the given file
2. Wait for the container to complete execution
3. Commit the resulting changes as a new image
4. Use the resulting image as the input of the next step


If all the steps succeed, the result will be an image containing the combined results of each build step.
You can trace back those build steps by inspecting the image's history:

    $ docker history $IMG
    ID                  CREATED             CREATED BY
    1e9e2045de86        A few seconds ago   /bin/sh -c cat > /usr/local/bin/myscript; chmod +x /usr/local/bin/git
    77db140aa62a        A few seconds ago   /bin/sh -c DEBIAN_FRONTEND=noninteractive apt-get install -y -q golang
    77db140aa62a        A few seconds ago   /bin/sh -c DEBIAN_FRONTEND=noninteractive apt-get install -y -q curl
    77db140aa62a        A few seconds ago   /bin/sh -c DEBIAN_FRONTEND=noninteractive apt-get install -y -q git 
    83e85d155451        A few seconds ago   /bin/sh -c apt-get update
    bfd53b36d9d3        A few seconds ago   /bin/sh -c echo 'deb http://archive.ubuntu.com/ubuntu quantal main universe multiverse' > /etc/apt/sources.list
    base		2 weeks ago         /bin/bash
    27cf78414709        2 weeks ago


Note that your build started from 'base', as instructed by your Changefile. But that base image itself seems to have been built in 2 steps - hence the extra step in the history.


You can use this build technique to create any image you want: a database, a web application, or anything else that can be build by a sequence of unix commands - in other words, anything else.