Image building ============== The ``tools/build-docker-image`` script in this repository is responsible for building docker images. It is symlinked as ``./build`` inside each Docker image directory. When creating new image directories, you can run the ``tools/update-build-links`` scripts to install the ``build`` symlink (this script will install the symlink anywhere it find a file named ``Dockerfile``). Workflow -------- In general, you will build images like this: :: $ cd docker/keystone $ ./build By default, the above command would build ``kollaglue/centos-rdo-keystone:CID``, where ``CID`` is the current short commit ID. That is, given: :: $ git rev-parse HEAD 76a16029006a2f5d3b79f1198d81acb6653110e9 The above command would generate ``kollaglue/centos-rdo-keystone:76a1602``. This tagging is meant to prevent developers from stepping on each other or on release images during the development process. To push the image after building, add ``--push``: :: $ ./build --push To use these images, you must specify the tag in your ``docker run`` commands: :: $ docker run kollaglue/centos-rdo-keystone:76a1602 Building releases ----------------- To build into the ``latest`` tag, add ``--release``: :: $ ./build --release Or to build and push: :: $ ./build --push --release Build all images at once ------------------------ The ``build-all-docker-images`` script in the tools directory is a wrapper for the ``build-docker-image`` that builds all images, as the name suggests, in the correct order. It responds to the same options as ``build-docker-image`` with the additional ``--from`` and ``--to`` options that allows building only images that have changed between the specified git revisions. For example, to build all images contained in docker directory and push new release: :: $ tools/build-all-docker-images --release --push To build only images modified in test-branch along with their children: :: $ tools/build-all-docker-images --from master --to test-branch Configuration ------------- The ``build-docker-image`` script will look for a file named ``.buildconf`` in the image directory and in the top level of the repository. You can use this to set defaults, such as: :: NAMESPACE=larsks PREFIX=fedora-rdo- This setting would cause images to be tagged into the ``larsks/`` namespace and use Fedora as base image instead of the default CentOS.