6e3127d043
This converts all MD formatted docs that were renamed to RST to preserve git history into actual RST documentation. Some minor edits were made but in general the purpose of this patch is to *only* convert the documentation not rework the documentation. I do plan on reworking the documentation in further patch sets. All links were tested and a test rendering is available: http://github.com/sdake/kolla Change-Id: I3df430b14df1ede15407c7f4ba7afcbdc6f9d757
102 lines
2.4 KiB
ReStructuredText
102 lines
2.4 KiB
ReStructuredText
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.
|