1 [Dockerfiles][] for assorted [Gentoo][]-based [Docker][] images.
3 Dockerfiles are sorted into directories with names matching the
4 suggested repository. To avoid duplicating ephemeral data (namespace,
5 timestamp tag, …), they appear in the `Dockerfile.template` as markers
6 (`${NAMESPACE}`, `${TAG}`, …). The `build.sh` script replaces the
7 markers with values while generating a `Dockerfile` from each
8 `Dockerfile.template` (using [envsubst][]), and then builds each tag
11 $ docker build -t $NAMESPACE/$REPO:$TAG $REPO
15 $ docker build -t wking/gentoo-en-us:20131205 gentoo-en-us
17 The dependency graph is:
19 wking/gentoo (amd64 stage3)
20 `-- gentoo-portage (adds portage directory)
21 `-- gentoo-en-us (adds locale)
22 `-- gentoo-syslog (adds syslog-ng and associates)
23 |-- buildbot (adds a Buildbot master and slave)
24 |-- docker-registry (adds a Docker registry server)
25 |-- memcached (adds Memcached)
26 |-- nginx (adds Nginx)
27 | |-- nginx-proxy (SSL/TLS proxying via SNI)
28 | `-- kibana (adds Kibana)
29 |-- postgresql (adds PostgreSQL)
30 |-- redis (adds Redis)
31 |-- stunnel (adds stunnel)
32 `-- gentoo-java (adds IcedTea)
33 `-- elasticsearch (adds Elasticsearch)
39 to seed from the Gentoo mirrors and build all images. There are a
40 number of variables in the `build.sh` script that configure the build
41 (`AUTHOR`, `NAMESPACE`, …). We use [POSIX parameter
42 expansion][parameter-expansion] to make it easy to override variables
45 $ NAMESPACE=jdoe DATE=20131210 ./build.sh
47 I'd like to avoid bloating the images with the Portage tree, but
48 without ugly hacks [that is not currently possible][3156].
50 [Docker]: http://www.docker.io/
51 [Dockerfiles]: http://www.docker.io/learn/dockerfile/
52 [Gentoo]: http://www.gentoo.org/
53 [envsubst]: http://www.gnu.org/software/gettext/manual/html_node/envsubst-Invocation.html
54 [parameter-expansion]: http://pubs.opengroup.org/onlinepubs/9699919799/utilities/V3_chap02.html#tag_18_06_02
55 [3156]: https://github.com/dotcloud/docker/issues/3156