Skip to content
This repository has been archived by the owner on Nov 16, 2018. It is now read-only.

Latest commit

 

History

History
123 lines (90 loc) · 5.6 KB

README.md

File metadata and controls

123 lines (90 loc) · 5.6 KB

docker-source-to-images (sti)

Source-to-images (sti) is a tool for building reproducable Docker images. sti produces ready-to-run images by injecting a user source into a docker image and preparing a new Docker image which incorporates the base image and built source, and is ready to use with docker run. sti supports:

  1. Incremental builds which re-use previously downloaded dependencies, previously built artifacts, etc
  2. Build on one image, deploy on another with extended builds

Interested in learning more? Read on!

Philosophy

  1. Simplify the process of application source + base image -> usable image for most use cases (the 80%)
  2. Define and implement a workflow for incremental build that eventually uses only docker primitives
  3. Develop tooling that can assist in verifying that two different base images result in the same "docker run" outcome for the same input
  4. Use native docker primitives to accomplish this - map out useful improvements to docker that benefit all image builders

Anatomy of a source image

Building source images is as easy as implementing two scripts. sti expects the following scripts in /usr/bin:

  1. prepare : This script is responsible for building and/or deploying the source
  2. run: This script is responsible for running the deployed source

Build methodologies

sti implements two methodologies for building Docker images. The first will be familiar to anyone who"s built their own Docker image before - it"s just docker build. When building this way, sti generates a Dockerfile and calls docker build to produce the output image:

  1. sti generates a Dockerfile to describe the output image:
    1. Based on the build image
    2. Adds the application source at /tmp/src in the container
    3. Calls /usr/bin/prepare in the container
    4. Sets the image"s default command to /usr/bin/run
  2. sti calls docker build to produce the output image

sti also supports building images with docker run. When building this way, the workflow is:

  1. sti creates a container based on the build image. with:
    1. The application source bind-mounted to /tmp/src
    2. The build artifacts bind-mounted to /tmp/artifacts (if applicable - see incremental builds)
    3. Runs the build image"s /usr/bin/prepare script
  2. sti starts the container and waits for it to finish running
  3. sti commits the container, setting the CMD for the output image to be /usr/bin/run

The build methodology is controlled by the -m option, and defaults to build. To build with docker run, use -m run.

Basic (--clean) builds

sti accepts the following inputs to do a build:

  1. Application source: this can be source code, zipped source, a binary, etc
  2. Build image: the basis for the new image to build
  3. Application image tag: the tag to use for the newly created application image

The basic build process is as follows:

  1. sti pulls the build image if it is not already present on the system
  2. sti builds the new image from the supplied build image and source, tagging the output image with the supplied tag

Incremental builds

sti automatically detects:

  1. Whether a source image is compatible with incremental building
  2. Whether an incremental build can be formed when an image is compatible

If the source image is compatible, a prior build already exists, and the --clean option is not used, the workflow is as follows:

  1. sti creates a new docker container from the prior build image, with a volume in /tmp/artifacts
  2. sti runs /usr/bin/save-artifacts in this container - this script is responsible for copying the build artifacts into /tmp/artifacts.
  3. sti builds the new output image using the selected build methodology:
    1. The artifacts from the previous build will be in /tmp/artifacts during the build
    2. The build image"s /usr/bin/prepare script is responsible for detecting and using the build artifacts

Note the invocation of the save-artifacts script; this script is responsible for moving build dependencies to /tmp/artifacts

Extended builds

Extended builds allow you to execute your build on a build image, then deploy it on a different runtime image. The workflow for extended builds is as follows:

  1. sti looks for the previous build image for the tag, <tag>-build.
  2. If that image exists:
    1. sti creates a container from this image and runs /usr/bin/save-artifacts in it
  3. sti creates a build container from the build image with a volume at /tmp/build and bind-mounts in the artifacts from the prior build, if applicable
  4. sti runs /usr/bin/prepare in the build container - this script is responsible for populating /tmp/build with the result of the build
  5. sti builds the output image with the selected build methodology:
    1. The base image will be the runtime image
    2. The output of the source build step will be in /tmp/src during the build
    3. The runtime image"s /usr/bin/prepare script is responsible for being able to deploy the artifact in /tmp/src
  6. If the docker build succeeds, the build container is tagged as <tag>-build

You might have noticed that the above workflow describes something like an incremental build. This behavior can be disabled with the --clean option.

Getting started

To get start, simply pick an implementation of sti and check out the README for instructions. There are currently two implementations of sti:

  1. A golang implementation
  2. A python implementation

Currently the golang implementation is the most feature completely and is the recommended implementation to use.